Rumah pangkalan data tutorial mysql SQLite关系型数据库的使用_MySQL

SQLite关系型数据库的使用_MySQL

May 27, 2016 pm 01:45 PM
pangkalan data

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)";

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimanakah bahasa Go melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data? Bagaimanakah bahasa Go melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data? Mar 27, 2024 pm 09:39 PM

Bahasa Go ialah bahasa pengaturcaraan yang cekap, ringkas dan mudah dipelajari Ia digemari oleh pembangun kerana kelebihannya dalam pengaturcaraan serentak dan pengaturcaraan rangkaian. Dalam pembangunan sebenar, operasi pangkalan data adalah bahagian yang sangat diperlukan Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data. Dalam bahasa Go, kami biasanya menggunakan perpustakaan pihak ketiga untuk mengendalikan pangkalan data, seperti pakej sql yang biasa digunakan, gorm, dsb. Di sini kami mengambil pakej sql sebagai contoh untuk memperkenalkan cara melaksanakan operasi penambahan, pemadaman, pengubahsuaian dan pertanyaan pangkalan data. Andaikan kami menggunakan pangkalan data MySQL.

iOS 18 menambah fungsi album 'Dipulihkan' baharu untuk mendapatkan semula foto yang hilang atau rosak iOS 18 menambah fungsi album 'Dipulihkan' baharu untuk mendapatkan semula foto yang hilang atau rosak Jul 18, 2024 am 05:48 AM

Keluaran terbaharu Apple bagi sistem iOS18, iPadOS18 dan macOS Sequoia telah menambah ciri penting pada aplikasi Photos, yang direka untuk membantu pengguna memulihkan foto dan video yang hilang atau rosak dengan mudah disebabkan pelbagai sebab. Ciri baharu ini memperkenalkan album yang dipanggil "Dipulihkan" dalam bahagian Alat pada apl Foto yang akan muncul secara automatik apabila pengguna mempunyai gambar atau video pada peranti mereka yang bukan sebahagian daripada pustaka foto mereka. Kemunculan album "Dipulihkan" menyediakan penyelesaian untuk foto dan video yang hilang akibat kerosakan pangkalan data, aplikasi kamera tidak disimpan ke pustaka foto dengan betul, atau aplikasi pihak ketiga yang menguruskan pustaka foto. Pengguna hanya memerlukan beberapa langkah mudah

Bagaimanakah Hibernate melaksanakan pemetaan polimorfik? Bagaimanakah Hibernate melaksanakan pemetaan polimorfik? Apr 17, 2024 pm 12:09 PM

Pemetaan polimorfik hibernate boleh memetakan kelas yang diwarisi ke pangkalan data dan menyediakan jenis pemetaan berikut: subkelas bercantum: Cipta jadual berasingan untuk subkelas, termasuk semua lajur kelas induk. table-per-class: Cipta jadual berasingan untuk subkelas, yang mengandungi hanya lajur khusus subkelas. union-subclass: serupa dengan joined-subclass, tetapi jadual kelas induk menggabungkan semua lajur subclass.

Apr 09, 2024 pm 12:36 PM

HTML tidak boleh membaca pangkalan data secara langsung, tetapi ia boleh dicapai melalui JavaScript dan AJAX. Langkah-langkah termasuk mewujudkan sambungan pangkalan data, menghantar pertanyaan, memproses respons dan mengemas kini halaman. Artikel ini menyediakan contoh praktikal menggunakan JavaScript, AJAX dan PHP untuk membaca data daripada pangkalan data MySQL, menunjukkan cara untuk memaparkan hasil pertanyaan secara dinamik dalam halaman HTML. Contoh ini menggunakan XMLHttpRequest untuk mewujudkan sambungan pangkalan data, menghantar pertanyaan dan memproses respons, dengan itu mengisi data ke dalam elemen halaman dan merealisasikan fungsi HTML membaca pangkalan data.

Tutorial terperinci tentang mewujudkan sambungan pangkalan data menggunakan MySQLi dalam PHP Tutorial terperinci tentang mewujudkan sambungan pangkalan data menggunakan MySQLi dalam PHP Jun 04, 2024 pm 01:42 PM

Cara menggunakan MySQLi untuk mewujudkan sambungan pangkalan data dalam PHP: Sertakan sambungan MySQLi (require_once) Cipta fungsi sambungan (functionconnect_to_db) Fungsi sambungan panggilan ($conn=connect_to_db()) Laksanakan pertanyaan ($result=$conn->query()) Tutup sambungan ( $conn->close())

Bagaimana untuk mengendalikan ralat sambungan pangkalan data dalam PHP Bagaimana untuk mengendalikan ralat sambungan pangkalan data dalam PHP Jun 05, 2024 pm 02:16 PM

Untuk mengendalikan ralat sambungan pangkalan data dalam PHP, anda boleh menggunakan langkah berikut: Gunakan mysqli_connect_errno() untuk mendapatkan kod ralat. Gunakan mysqli_connect_error() untuk mendapatkan mesej ralat. Dengan menangkap dan mengelog mesej ralat ini, isu sambungan pangkalan data boleh dikenal pasti dan diselesaikan dengan mudah, memastikan kelancaran aplikasi anda.

Petua dan amalan untuk mengendalikan aksara Cina bercelaru dalam pangkalan data dengan PHP Petua dan amalan untuk mengendalikan aksara Cina bercelaru dalam pangkalan data dengan PHP Mar 27, 2024 pm 05:21 PM

PHP ialah bahasa pengaturcaraan bahagian belakang yang digunakan secara meluas dalam pembangunan laman web Ia mempunyai fungsi operasi pangkalan data yang kuat dan sering digunakan untuk berinteraksi dengan pangkalan data seperti MySQL. Walau bagaimanapun, disebabkan kerumitan pengekodan aksara Cina, masalah sering timbul apabila berurusan dengan aksara Cina bercelaru dalam pangkalan data. Artikel ini akan memperkenalkan kemahiran dan amalan PHP dalam mengendalikan aksara bercelaru bahasa Cina dalam pangkalan data, termasuk punca biasa aksara bercelaru, penyelesaian dan contoh kod khusus. Sebab biasa aksara bercelaru ialah tetapan set aksara pangkalan data yang salah: set aksara yang betul perlu dipilih semasa mencipta pangkalan data, seperti utf8 atau u

Bagaimana untuk menyambung ke pangkalan data jauh menggunakan Golang? Bagaimana untuk menyambung ke pangkalan data jauh menggunakan Golang? Jun 01, 2024 pm 08:31 PM

Melalui pakej pangkalan data/sql perpustakaan standard Go, anda boleh menyambung ke pangkalan data jauh seperti MySQL, PostgreSQL atau SQLite: buat rentetan sambungan yang mengandungi maklumat sambungan pangkalan data. Gunakan fungsi sql.Open() untuk membuka sambungan pangkalan data. Lakukan operasi pangkalan data seperti pertanyaan SQL dan operasi sisipan. Gunakan tangguh untuk menutup sambungan pangkalan data untuk mengeluarkan sumber.

See all articles