ホームページ データベース mysql チュートリアル 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)";

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか? Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか? Mar 27, 2024 pm 09:39 PM

Go 言語は、効率的かつ簡潔で習得が容易なプログラミング言語であり、同時プログラミングやネットワーク プログラミングに優れているため、開発者に好まれています。実際の開発ではデータベースの操作が欠かせませんが、今回はGo言語を使ってデータベースの追加・削除・変更・クエリ操作を実装する方法を紹介します。 Go 言語では、データベースを操作するために通常、よく使用される SQL パッケージや gorm などのサードパーティ ライブラリを使用します。ここでは SQL パッケージを例として、データベースの追加、削除、変更、クエリ操作を実装する方法を紹介します。 MySQL データベースを使用していると仮定します。

iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます Jul 18, 2024 am 05:48 AM

Apple の最新リリースの iOS18、iPadOS18、および macOS Sequoia システムでは、さまざまな理由で紛失または破損した写真やビデオをユーザーが簡単に回復できるように設計された重要な機能が写真アプリケーションに追加されました。この新機能では、写真アプリのツール セクションに「Recovered」というアルバムが導入され、ユーザーがデバイス上に写真ライブラリに含まれていない写真やビデオがある場合に自動的に表示されます。 「Recovered」アルバムの登場により、データベースの破損、カメラ アプリケーションが写真ライブラリに正しく保存されない、または写真ライブラリを管理するサードパーティ アプリケーションによって失われた写真やビデオに対する解決策が提供されます。ユーザーはいくつかの簡単な手順を実行するだけで済みます

Hibernate はポリモーフィック マッピングをどのように実装しますか? Hibernate はポリモーフィック マッピングをどのように実装しますか? Apr 17, 2024 pm 12:09 PM

Hibernate ポリモーフィック マッピングは、継承されたクラスをデータベースにマップでき、次のマッピング タイプを提供します。 join-subclass: 親クラスのすべての列を含む、サブクラス用の別個のテーブルを作成します。 table-per-class: サブクラス固有の列のみを含む、サブクラス用の別個のテーブルを作成します。 Union-subclass: join-subclass と似ていますが、親クラス テーブルがすべてのサブクラス列を結合します。

HTML がデータベースを読み取る方法の詳細な分析 HTML がデータベースを読み取る方法の詳細な分析 Apr 09, 2024 pm 12:36 PM

HTML はデータベースを直接読み取ることはできませんが、JavaScript と AJAX を通じて実現できます。この手順には、データベース接続の確立、クエリの送信、応答の処理、ページの更新が含まれます。この記事では、JavaScript、AJAX、および PHP を使用して MySQL データベースからデータを読み取る実践的な例を示し、クエリ結果を HTML ページに動的に表示する方法を示します。この例では、XMLHttpRequest を使用してデータベース接続を確立し、クエリを送信して応答を処理することで、ページ要素にデータを埋め込み、データベースを読み取る HTML の機能を実現します。

PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル Jun 04, 2024 pm 01:42 PM

MySQLi を使用して PHP でデータベース接続を確立する方法: MySQLi 拡張機能を含める (require_once) 接続関数を作成する (functionconnect_to_db) 接続関数を呼び出す ($conn=connect_to_db()) クエリを実行する ($result=$conn->query()) 閉じる接続 ( $conn->close())

PHP でデータベース接続エラーを処理する方法 PHP でデータベース接続エラーを処理する方法 Jun 05, 2024 pm 02:16 PM

PHP でデータベース接続エラーを処理するには、次の手順を使用できます。 mysqli_connect_errno() を使用してエラー コードを取得します。 mysqli_connect_error() を使用してエラー メッセージを取得します。これらのエラー メッセージをキャプチャしてログに記録することで、データベース接続の問題を簡単に特定して解決でき、アプリケーションをスムーズに実行できるようになります。

PHP を使用してデータベース内の中国語の文字化けを処理するためのヒントと実践 PHP を使用してデータベース内の中国語の文字化けを処理するためのヒントと実践 Mar 27, 2024 pm 05:21 PM

PHP は Web サイト開発で広く使用されているバックエンド プログラミング言語であり、強力なデータベース操作機能を備えており、MySQL などのデータベースとの対話によく使用されます。ただし、中国語の文字エンコーディングは複雑であるため、データベース内で中国語の文字化けを処理するときに問題が発生することがよくあります。この記事では、文字化けの一般的な原因、解決策、具体的なコード例を含め、データベース内の中国語の文字化けを処理するための PHP のスキルと実践方法を紹介します。文字化けの一般的な原因は、データベースの文字セット設定が正しくないことです。データベースの作成時に、utf8 や u などの正しい文字セットを選択する必要があります。

Golangを使用してリモートデータベースに接続するにはどうすればよいですか? Golangを使用してリモートデータベースに接続するにはどうすればよいですか? Jun 01, 2024 pm 08:31 PM

Go 標準ライブラリのデータベース/SQL パッケージを通じて、MySQL、PostgreSQL、SQLite などのリモート データベースに接続できます。データベース接続情報を含む接続文字列を作成します。 sql.Open() 関数を使用してデータベース接続を開きます。 SQL クエリや挿入操作などのデータベース操作を実行します。 defer を使用してデータベース接続を閉じ、リソースを解放します。

See all articles