Heim Datenbank MySQL-Tutorial SQLite关系型数据库的使用_MySQL

SQLite关系型数据库的使用_MySQL

May 27, 2016 pm 01:45 PM
数据库

SQLite关系型数据库的使用

 

数据库(Database): 存放数据的仓库, 存放的是一张的表, 特别像Excel, Numbers, 都以表格的形式存放数据, 可以创建多张表。

 

常见的数据库: sqlite, MySQL, SQLServer, Oracle, Access。

使用数据库,主要是因为文件读写和归档读取数据需要一次把数据全部读出来, 占用内存开销大;其次是数据库数据效率高, 体现在增删改查。

 

数据库存储数据的步骤

1、新建一个数据库

2、新建一张表(table)

3、添加多个字段(column,列,属性)

4、添加多行记录(row,每行存放多个字段对应的值)

 

数据库的操作语句 (增删改查),即SQL(Structured Query Language)

SQL 语句不区分大小写, 字符串需要加""或''

常用语法:(主键: 是一条数据的唯一标示符, 一张表只能有一个主键, 主键不能够重复, 一般把主键名设为"id", 不需要赋值, 会自增;*代表所有的字段;where是条件)

1 表操作

(1)创建表: creat table 表名 (字段名字段数据类型 是否为主键, 字段名 字段数据类型, 字段名 字段数据类型...)

(2)修改表名:ALTER TABLE 旧表名 RENAME TO 新表名

(3)删除表:DROP TABLE 表名

(4)表添加一列:ALTER TABLE 表名 ADD COLUMN 列名数据类型 限定符

2 表数据操作

(1)查: select 字段名 (或者*) from 表名 where 字段名 = 值

(2)加: insert into 表名 (字段1, 字段2...) values (值1, 值2...)

(3)改: update 表名 set 字段 = 值 where 字段 = 值

(4)删: delete from 表名 where 字段 = 值

 

SQLite是一款轻型的嵌入式数据库,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就足够了。它的处理速度比Mysql、PostgreSQL这两款著名的数据库都还快。

 

SQLite名词解释

2个重要结构体

1 sqlite3 *pdb(数据库句柄,跟文件句柄FILE类似)

2 sqlite3_stmt *stmt(这个相当于ODBC的Command对象,用于保存编译好的SQL语句)

5个主要函数

1 sqlite3_open()(打开数据库)

2 sqlite3_exec()(执行非查询的sql语句)

3 sqlite3_prepare()(准备sql语句,执行select语句或者要使用parameterbind时,用这个函数(封装了sqlite3_exec))

4 Sqlite3_step()(在调用sqlite3_prepare后,使用这个函数在记录集中移动)

5 Sqlite3_close()(关闭数据库文件)

 

SQLite 存储类

1 NULL(值是一个 NULL 值)

2 INTEGER(值是一个带符号的整数,根据值的大小存储在1、2、3、4、6 或 8 字节中)

3 REAL(值是一个浮点值,存储为 8 字节的 IEEE 浮点数字)

4 TEXT (值是一个文本字符串,使用数据库编码(UTF-8、UTF-16BE 或 UTF-16LE)存储)

5 BLOB (值是一个 blob 数据,完全根据它的输入存储)

 

SQLite常用语句

1、打开数据库 sqlite3_open函数

2、预处理SQL语句sqlite3_prepare_v2函数

3、绑定参数sqlite3_bind_text函数

4、执行SQL语句sqlite3_step函数(状态:*SQLITE_BUSY-数据库被锁定、*SQLITE_DONE-成功执行过程、*SQLITE_ROW-返回一行结果、*SQLITE_ERROR-运行错误、*SQLITE_MISUSE-错误的使用了本函数)

5、提取字段数据sqlite3_column_text、sqlite3_column_blob、sqlite3_column_int等函数

6、释放statement对象资源 sqlite3_finalize函数

7、关闭数据库 sqlite3_close函数

 

SQLite的使用

1、在iOS中使用SQLite时,首先需要添加库文件libsqlite3.tbd

\

 

2、导入主头文件 #import

\

 

3、数据库操作(注:设置数据库名称及路径)

 

示例代码:

设置数据库路径

- (void)setSQLitePath

{

if (self.filePath == nil)

{

// document目录下

NSArray *documentArray =NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask,YES);

NSString *document = [documentArray objectAtIndex:0];

_filePath = [document stringByAppendingPathComponent:SQLiteFile];

}

 

NSLog(@"filePath %@", _filePath);

}

 

打开数据库,创建表

- (void)New

{

NSString *sql = @"CREATE TABLE IF NOT EXISTS STUDENT(NAME TEXTPRIMARY KEY, ADDRESS TEXT, PHONE TEXT)";

if (sql && 0 != sql.length)

{

[self setSQLitePath];

 

if ([[NSFileManager defaultManager] fileExistsAtPath:self.filePath])

{

// 打开数据库

sqlite3 *dataBase; // sqlite3

const char *fileName = [self.filePath UTF8String]; // [xxx UTF8String]是将NSString转换为C字符串,因为SQLite3是采用可移植的C(而不是 Objective-C)编写的,它不知道什么是NSString.

int openStatus = sqlite3_open(fileName, &dataBase);

if (openStatus != SQLITE_OK)

{

// 数据库打开失败,关闭数据库

sqlite3_close(dataBase);

NSAssert(0, @"打开数据库失败");

 

NSLog(@"打开数据库失败");

}

 

NSLog(@"打开数据库成功");

 

// 创建表

char *errorMsg;

const char *execSql = [sql UTF8String];

int execStatus = sqlite3_exec(dataBase,execSql, NULL, NULL, &errorMsg);

if (execStatus != SQLITE_OK)

{

// 创建表失败,关闭数据库

sqlite3_close(dataBase);

NSAssert1(0, @"创建表失败:%s",errorMsg);

}

 

NSLog(@"创建表成功");

}

}

}

 

插入数据

- (void)Insert

{

// ?号表示一个未定的值

NSString *sql = @"INSERT OR REPLACE INTO STUDENT (NAME, ADDRESS,PHONE) VALUES (?,?,?)";

if (sql && 0 != sql.length)

{

[self setSQLitePath];

 

if ([[NSFileManager defaultManager] fileExistsAtPath:self.filePath])

{

// 打开数据库

sqlite3 *dataBase; // sqlite3

const char *fileName = [self.filePath UTF8String];

int openStatus = sqlite3_open(fileName,&dataBase);

if (openStatus != SQLITE_OK)

{

// 数据库打开失败,关闭数据库

sqlite3_close(dataBase);

NSAssert(0, @"打开数据库失败");

 

NSLog(@"打开数据库失败");

}

 

NSLog(@"打开数据库成功");

 

 

const char *execSql = [sql UTF8String];

sqlite3_stmt *statment;

int execStatus = sqlite3_prepare_v2(dataBase, execSql, -1,&statment, nil); // 接口把一条SQL语句解析到statement结构里去. 使用该接口访问数据库是当前比较好的的一种方法

if (execStatus == SQLITE_OK)

{

NSLog(@"插入更新表成功");

 

// 绑定参数开始

// 这里的数字1,2,3代表上面的第几个问号,这里将三个值绑定到三个绑定变量

sqlite3_bind_text(statment, 1,[@"zhangshaoyu" UTF8String], -1, NULL);

sqlite3_bind_text(statment, 2,[@"meizhou" UTF8String], -1, NULL);

sqlite3_bind_text(statment, 3,[@"13800138000" UTF8String], -1, NULL);

 

// 执行SQL语句 执行插入

if (sqlite3_step(statment) !=SQLITE_DONE)

{

NSAssert(NO, @"插入更新表失败。");

}

else

{

NSLog(@"插入更新表成功");

}

}

else

{

NSLog(@"插入更新表失败");

}

 

// 释放sqlite3_stmt对象资源

sqlite3_finalize(statment);

 

// 关闭数据库

sqlite3_close(dataBase);

}

}

}

 

修改更新数据

- (void)Update

{

NSString *sql = @"UPDATE STUDENT SET ADDRESS = ? where NAME =?";

 

if (sql && 0 != sql.length)

{

[self setSQLitePath];

 

if ([[NSFileManager defaultManager]fileExistsAtPath:self.filePath])

{

// 打开数据库

sqlite3 *dataBase; // sqlite3

const char *fileName = [self.filePath UTF8String];

int openStatus = sqlite3_open(fileName, &dataBase);

if (openStatus != SQLITE_OK)

{

// 数据库打开失败,关闭数据库

sqlite3_close(dataBase);

NSAssert(0, @"打开数据库失败");

 

NSLog(@"打开数据库失败");

}

 

NSLog(@"打开数据库成功");

 

const char *execSql = [sql UTF8String];

sqlite3_stmt *statment;

int execStatus = sqlite3_prepare_v2(dataBase, execSql, -1,&statment, nil);

if (execStatus == SQLITE_OK)

{

NSLog(@"更新表成功");

 

// 绑定text类型的数据库数据

// 这里的数字1,2,3代表第几个问号。这里只有1个问号,这是一个相对比较简单的数据库操作,真正的项目中会远远比这个复杂

sqlite3_bind_text(statment, 1,[@"meizhouWUHUA" UTF8String], -1, NULL);

sqlite3_bind_text(statment, 2,[@"zhangshaoyu" UTF8String], -1, NULL);

 

// 执行插入

if (sqlite3_step(statment) !=SQLITE_DONE)

{

NSAssert(NO, @"更新表失败。");

}

else

{

NSLog(@"更新表成功");

}

}

else

{

NSLog(@"更新表失败");

}

 

// 释放sqlite3_stmt对象资源

sqlite3_finalize(statment);

 

// 关闭数据库

sqlite3_close(dataBase);

}

}

}

 

查找数据

- (void)Select

{

NSString *sql = @"SELECT * FROM STUDENT";

if (sql && 0 != sql.length)

{

[self setSQLitePath];

 

if ([[NSFileManager defaultManager] fileExistsAtPath:self.filePath])

{

// 打开数据库

sqlite3 *dataBase; // sqlite3

const char *fileName = [self.filePath UTF8String];

int openStatus = sqlite3_open(fileName, &dataBase);

if (openStatus != SQLITE_OK)

{

// 数据库打开失败,关闭数据库

sqlite3_close(dataBase);

NSAssert(0, @"打开数据库失败");

 

NSLog(@"打开数据库失败");

}

 

NSLog(@"打开数据库成功");

 

const char *execSql = [sql UTF8String];

sqlite3_stmt *statment;

int execStatus = sqlite3_prepare_v2(dataBase, execSql, -1,&statment, nil);

if (execStatus == SQLITE_OK)

{

NSLog(@"查询成功");

 

// 查询成功,执行遍历操作

// 查询结果集中一条一条的遍历所有的记录,这里的数字对应的是列值,注意这里的列值,跟上面sqlite3_bind_text绑定的列值不一样!一定要分开,不然会crash,只有这一处的列号不同,注意!

while(sqlite3_step(statment) ==SQLITE_ROW)

{

const char *NAME = (char*)sqlite3_column_text(statment, 0);

if (NAME != NULL)

{

NSString *name =[[NSString alloc] initWithUTF8String:NAME];

NSLog(@"NAME%@", name);

}

 

char *ADDRESS = (char*)sqlite3_column_text(statment, 1);

if (ADDRESS != NULL)

{

NSString *address =[[NSString alloc] initWithUTF8String:ADDRESS];

NSLog(@"ADDRESS%@", address);

}

 

char *PHONE = (char*)sqlite3_column_text(statment, 2);

if (PHONE != NULL)

{

NSString *phone =[[NSString alloc] initWithUTF8String:PHONE];

NSLog(@"PHONE%@", phone);

}

}

}

else

{

NSLog(@"查询失败");

}

 

// 释放sqlite3_stmt对象资源

sqlite3_finalize(statment);

 

// 关闭数据库

sqlite3_close(dataBase);

}

}

}

 

 

 

删除数据

- (void)Delete

{

//NSString *sql = @"DELETE FROM STUDENT"; // 方法1

NSString *sql = @"DELETE FROM STUDENT where NAME = ?"; // 方法2

if (sql && 0 != sql.length)

{

[self setSQLitePath];

 

if ([[NSFileManager defaultManager] fileExistsAtPath:self.filePath])

{

// 打开数据库

sqlite3 *dataBase; // sqlite3

const char *fileName = [self.filePath UTF8String];

int openStatus = sqlite3_open(fileName,&dataBase);

if (openStatus != SQLITE_OK)

{

// 数据库打开失败,关闭数据库

sqlite3_close(dataBase);

NSAssert(0, @"打开数据库失败");

 

NSLog(@"打开数据库失败");

}

 

NSLog(@"打开数据库成功");

 

const char *execSql = [sql UTF8String];

sqlite3_stmt *statment;

int execStatus = sqlite3_prepare_v2(dataBase, execSql, -1, &statment,nil);

if (execStatus == SQLITE_OK)

{

// 绑定text类型的数据库数据

// 这里的数字1,2,3代表第几个问号。这里只有1个问号,这是一个相对比较简单的数据库操作,真正的项目中会远远比这个复杂

sqlite3_bind_text(statment, 1,[@"zhangshaoyu" UTF8String], -1, NULL);

 

// 执行删除

if (sqlite3_step(statment) !=SQLITE_DONE)

{

NSAssert(NO, @"删除数据失败。");

NSLog(@"删除数据失败");

}

else

{

NSLog(@"删除数据成功");

}

}

else

{

NSLog(@"删除数据失败");

}

 

// 释放sqlite3_stmt对象资源

sqlite3_finalize(statment);

 

// 关闭数据库

sqlite3_close(dataBase);

}

}

}

 

删除表

- (void)DeleteTable

{

NSString *sql = @"DROP TABLE STUDENT";

if (sql && 0 != sql.length)

{

[self setSQLitePath];

 

if ([[NSFileManager defaultManager] fileExistsAtPath:self.filePath])

{

// 打开数据库

sqlite3 *dataBase; // sqlite3

const char *fileName = [self.filePath UTF8String];

int openStatus = sqlite3_open(fileName, &dataBase);

if (openStatus != SQLITE_OK)

{

// 数据库打开失败,关闭数据库

sqlite3_close(dataBase);

NSAssert(0, @"打开数据库失败");

 

NSLog(@"打开数据库失败");

}

 

NSLog(@"打开数据库成功");

 

const char *execSql = [sql UTF8String];

sqlite3_stmt *statment;

int execStatus = sqlite3_prepare_v2(dataBase, execSql, -1,&statment, nil);

if (execStatus == SQLITE_OK)

{

// 执行删除

if (sqlite3_step(statment) !=SQLITE_DONE)

{

NSAssert(NO, @"删除表失败。");

NSLog(@"删除表失败");

}

else

{

NSLog(@"删除表成功");

}

}

else

{

NSLog(@"删除表失败");

}

 

// 释放sqlite3_stmt对象资源

sqlite3_finalize(statment);

 

// 关闭数据库

sqlite3_close(dataBase);

}

}

}

 

数据查看

\

\

\

 

 

 

注意事项:

1、由于sqlite3是基于C语言编写的,而不是纯粹的object-c,所以有关字符串,我们不能使用NSString,因为它不识别,所以只能用c语言的字符串,char*,好在Nsstring提供了转换的方法,那就是 UTF8String。如:

NSString*sql = @"DELETE FROM STUDENT where NAME = ?";

constchar *execSql = [sql UTF8String];

2、sql语句中,不确定值使用?符号。如:

NSString*sql = @"DELETE FROM STUDENT where NAME = ?";

3、提取查询数据函数中的数字表示sql语句中的第几列(0~N)。如:

表示第1列:constchar *NAME = (char *)sqlite3_column_text(statment, 0);

4、绑定数据时函数中的数字表示sql语句中的第几个值。如:

NSString*sql = @"INSERT OR REPLACE INTO STUDENT (NAME, ADDRESS, PHONE) VALUES(?,?,?)";

表示第1个值:sqlite3_bind_text(statment,1, [@"zhangshaoyu" UTF8String], -1, NULL);

表示第2个值:sqlite3_bind_text(statment,2, [@"meizhou" UTF8String], -1, NULL);

表示第3个值:sqlite3_bind_text(statment,3, [@"13510213244" UTF8String], -1, NULL);

5、创建表时,必须设置一个主键PRIMARY KEY。如:

NSString*sql = @"CREATE TABLE IF NOT EXISTS STUDENT(NAME TEXT PRIMARY KEY, ADDRESSTEXT, PHONE TEXT)";

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie implementiert die Go-Sprache die Hinzufügungs-, Lösch-, Änderungs- und Abfragevorgänge der Datenbank? Wie implementiert die Go-Sprache die Hinzufügungs-, Lösch-, Änderungs- und Abfragevorgänge der Datenbank? Mar 27, 2024 pm 09:39 PM

Die Go-Sprache ist eine effiziente, prägnante und leicht zu erlernende Programmiersprache. Sie wird von Entwicklern aufgrund ihrer Vorteile bei der gleichzeitigen Programmierung und Netzwerkprogrammierung bevorzugt. In der tatsächlichen Entwicklung sind Datenbankoperationen ein unverzichtbarer Bestandteil. In diesem Artikel wird erläutert, wie die Go-Sprache zum Implementieren von Datenbank-Hinzufügungs-, Lösch-, Änderungs- und Abfrageoperationen verwendet wird. In der Go-Sprache verwenden wir normalerweise Bibliotheken von Drittanbietern, um Datenbanken zu betreiben, z. B. häufig verwendete SQL-Pakete, Gorm usw. Hier nehmen wir das SQL-Paket als Beispiel, um vorzustellen, wie die Hinzufügungs-, Lösch-, Änderungs- und Abfragevorgänge der Datenbank implementiert werden. Angenommen, wir verwenden eine MySQL-Datenbank.

iOS 18 fügt eine neue Albumfunktion „Wiederhergestellt' hinzu, um verlorene oder beschädigte Fotos wiederherzustellen iOS 18 fügt eine neue Albumfunktion „Wiederhergestellt' hinzu, um verlorene oder beschädigte Fotos wiederherzustellen Jul 18, 2024 am 05:48 AM

Apples neueste Versionen der iOS18-, iPadOS18- und macOS Sequoia-Systeme haben der Fotoanwendung eine wichtige Funktion hinzugefügt, die Benutzern dabei helfen soll, aus verschiedenen Gründen verlorene oder beschädigte Fotos und Videos einfach wiederherzustellen. Mit der neuen Funktion wird im Abschnitt „Extras“ der Fotos-App ein Album mit dem Namen „Wiederhergestellt“ eingeführt, das automatisch angezeigt wird, wenn ein Benutzer Bilder oder Videos auf seinem Gerät hat, die nicht Teil seiner Fotobibliothek sind. Das Aufkommen des Albums „Wiederhergestellt“ bietet eine Lösung für Fotos und Videos, die aufgrund einer Datenbankbeschädigung verloren gehen, die Kameraanwendung nicht korrekt in der Fotobibliothek speichert oder eine Drittanbieteranwendung die Fotobibliothek verwaltet. Benutzer benötigen nur wenige einfache Schritte

Wie implementiert Hibernate polymorphe Zuordnung? Wie implementiert Hibernate polymorphe Zuordnung? Apr 17, 2024 pm 12:09 PM

Die polymorphe Hibernate-Zuordnung kann geerbte Klassen der Datenbank zuordnen und bietet die folgenden Zuordnungstypen: Joined-Subclass: Erstellen Sie eine separate Tabelle für die Unterklasse, einschließlich aller Spalten der übergeordneten Klasse. Tabelle pro Klasse: Erstellen Sie eine separate Tabelle für Unterklassen, die nur unterklassenspezifische Spalten enthält. Union-Unterklasse: ähnelt der verbundenen Unterklasse, aber die Tabelle der übergeordneten Klasse vereint alle Spalten der Unterklasse.

Eine ausführliche Analyse, wie HTML die Datenbank liest Eine ausführliche Analyse, wie HTML die Datenbank liest Apr 09, 2024 pm 12:36 PM

HTML kann die Datenbank nicht direkt lesen, dies kann jedoch über JavaScript und AJAX erreicht werden. Zu den Schritten gehören das Herstellen einer Datenbankverbindung, das Senden einer Abfrage, das Verarbeiten der Antwort und das Aktualisieren der Seite. Dieser Artikel bietet ein praktisches Beispiel für die Verwendung von JavaScript, AJAX und PHP zum Lesen von Daten aus einer MySQL-Datenbank und zeigt, wie Abfrageergebnisse dynamisch auf einer HTML-Seite angezeigt werden. In diesem Beispiel wird XMLHttpRequest verwendet, um eine Datenbankverbindung herzustellen, eine Abfrage zu senden und die Antwort zu verarbeiten. Dadurch werden Daten in Seitenelemente gefüllt und die Funktion des HTML-Lesens der Datenbank realisiert.

Ausführliches Tutorial zum Herstellen einer Datenbankverbindung mit MySQLi in PHP Ausführliches Tutorial zum Herstellen einer Datenbankverbindung mit MySQLi in PHP Jun 04, 2024 pm 01:42 PM

So verwenden Sie MySQLi zum Herstellen einer Datenbankverbindung in PHP: MySQLi-Erweiterung einbinden (require_once) Verbindungsfunktion erstellen (functionconnect_to_db) Verbindungsfunktion aufrufen ($conn=connect_to_db()) Abfrage ausführen ($result=$conn->query()) Schließen Verbindung ( $conn->close())

Umgang mit Datenbankverbindungsfehlern in PHP Umgang mit Datenbankverbindungsfehlern in PHP Jun 05, 2024 pm 02:16 PM

Um Datenbankverbindungsfehler in PHP zu behandeln, können Sie die folgenden Schritte ausführen: Verwenden Sie mysqli_connect_errno(), um den Fehlercode abzurufen. Verwenden Sie mysqli_connect_error(), um die Fehlermeldung abzurufen. Durch die Erfassung und Protokollierung dieser Fehlermeldungen können Datenbankverbindungsprobleme leicht identifiziert und behoben werden, wodurch der reibungslose Betrieb Ihrer Anwendung gewährleistet wird.

Tipps und Praktiken zum Umgang mit verstümmelten chinesischen Zeichen in Datenbanken mit PHP Tipps und Praktiken zum Umgang mit verstümmelten chinesischen Zeichen in Datenbanken mit PHP Mar 27, 2024 pm 05:21 PM

PHP ist eine Back-End-Programmiersprache, die in der Website-Entwicklung weit verbreitet ist. Sie verfügt über leistungsstarke Datenbankbetriebsfunktionen und wird häufig zur Interaktion mit Datenbanken wie MySQL verwendet. Aufgrund der Komplexität der Kodierung chinesischer Zeichen treten jedoch häufig Probleme beim Umgang mit verstümmelten chinesischen Zeichen in der Datenbank auf. In diesem Artikel werden die Fähigkeiten und Praktiken von PHP beim Umgang mit chinesischen verstümmelten Zeichen in Datenbanken vorgestellt, einschließlich häufiger Ursachen für verstümmelte Zeichen, Lösungen und spezifischer Codebeispiele. Häufige Gründe für verstümmelte Zeichen sind falsche Einstellungen für den Datenbank-Zeichensatz: Beim Erstellen der Datenbank muss der richtige Zeichensatz ausgewählt werden, z. B. utf8 oder u

Wie verbinde ich mich mit Golang mit einer Remote-Datenbank? Wie verbinde ich mich mit Golang mit einer Remote-Datenbank? Jun 01, 2024 pm 08:31 PM

Über das Datenbank-/SQL-Paket der Go-Standardbibliothek können Sie eine Verbindung zu Remote-Datenbanken wie MySQL, PostgreSQL oder SQLite herstellen: Erstellen Sie eine Verbindungszeichenfolge mit Datenbankverbindungsinformationen. Verwenden Sie die Funktion sql.Open(), um eine Datenbankverbindung zu öffnen. Führen Sie Datenbankoperationen wie SQL-Abfragen und Einfügeoperationen durch. Verwenden Sie „defer“, um die Datenbankverbindung zu schließen und Ressourcen freizugeben.

See all articles