sqlite3数据库的使用

新建一个Sigle View Application,命名为Persistence_sqlite

为工程添加sqlite3的库libsqlite3.dylib(点击工程->Build Phases->Link Binary With Libraries->添加libsqlite3.dylib).

修改ViewController.xib,添加4个Label控件和4个TextField控件

修改ViewController.h如下,并连接输出口name、gender、age、education

#definekDataKey @"Data"

#definekSqliteFileName @"data.db3"

@interfaceViewController : UIViewController

@property(nonatomic,retain)IBOutletUITextField *name;

@property(nonatomic,retain)IBOutletUITextField *gender;

@property(nonatomic,retain)IBOutletUITextField *age;

@property(nonatomic,retain)IBOutletUITextField *education;

-(NSString*)dataFilePath;

-(void)applicationWillResignActive:(NSNotification*)nofication;

@end

修改ViewController.m如下

#import<sqlite3.h>

@implementationViewController

@synthesizename,gender,age,education;

 

-(NSString*)dataFilePath{

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

   NSString *documentsDirectory = [paths objectAtIndex:0];

   //return [documentsDirectory stringByAppendingPathComponent:kFileName];

   return [documentsDirectory stringByAppendingPathComponent:kSqliteFileName];

}

 

-(void)didReceiveMemoryWarning

{

   [super didReceiveMemoryWarning];

   // Release any cached data, images, etc that aren't in use.

}

 

#pragma mark -View lifecycle

 

-(void)viewDidLoad

{

   // Do any additional setup after loading the view, typically from a nib.

   NSString *filePath = [self dataFilePath];

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

   

   if([[NSFileManager defaultManager] fileExistsAtPath:filePath]){

       

       //sqlite3

       sqlite3 *database;

       //打开数据库

       if(sqlite3_open([filePath UTF8String],&database)!=SQLITE_OK){//备注1

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

           sqlite3_close(database);

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

       }

       

       char* errorMsg;

       NSString *createSQL = @"CREATE TABLE IF NOT EXISTS PERSON(name TEXT PRIMARY KEY,gender TEXT,age TEXT,education TEXT);";

       //创建表

       if(sqlite3_exec(database, [createSQL UTF8String], NULL, NULL,&errorMsg)!=SQLITE_OK){//备注2

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

           sqlite3_close(database);

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

       }

       

       //查询表

       NSString *querySQL = @"SELECT name,gender,age,education FROMPERSON ORDER BY name";

       

       //执行查询,遍历查询结果

       sqlite3_stmt *statment;

       if(sqlite3_prepare_v2(database, [querySQL UTF8String], -1,&statment, nil) == SQLITE_OK){//备注3

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

           while(sqlite3_step(statment) == SQLITE_ROW){//备注4

               const char* pName =(char*)sqlite3_column_text(statment, 0);//备注5

               if(pName!=NULL){

                   self.name.text =[[NSString alloc]initWithUTF8String:pName];

               }

               

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

               if(pGender!=NULL){

                   self.gender.text =[[NSString alloc]initWithUTF8String:pGender];

               }

               

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

               if(pAge!=NULL){

                   self.age.text =[[NSString alloc]initWithUTF8String:pAge];

               }

               

               char* pEducation =(char*)sqlite3_column_text(statment, 3);

               if(pEducation!=NULL){

                   self.education.text =[[NSString alloc]initWithUTF8String:pEducation];

               }

           }

           sqlite3_finalize(statment);//备注6

       }

       //关闭数据库

       sqlite3_close(database);//备注7

    }

   

   UIApplication *app = [UIApplication sharedApplication];

   [[NSNotificationCenter defaultCenter] addObserver:selfselector:@selector(applicationWillResignActive:) name:UIApplicationWillResignActiveNotificationobject:app];

   

   [super viewDidLoad];

}

 

-(void)applicationWillResignActive:(NSNotification*)nofication{

   

   

   

   //sqlite3

   sqlite3 *database;

   //打开数据库

   if(sqlite3_open([[self dataFilePath] UTF8String], &database)!=SQLITE_OK){

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

       sqlite3_close(database);

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

    }

   

   char* errorMsg;

   NSString *updateSQL = @"INSERT OR REPLACE INTOPERSON(name,gender,age,education) VALUES(?,?,?,?);";

   //执行插入或更新操作

   sqlite3_stmt *statment;

   if(sqlite3_prepare_v2(database, [updateSQL UTF8String], -1, &statment, nil)== SQLITE_OK){

       //绑定变量

       sqlite3_bind_text(statment, 1, [self.name.text UTF8String], -1,NULL);//备注8

       sqlite3_bind_text(statment, 2, [self.gender.text UTF8String], -1,NULL);

       sqlite3_bind_text(statment, 3, [self.age.text UTF8String], -1,NULL);

       sqlite3_bind_text(statment, 4, [self.education.text UTF8String],-1, NULL);

    }

   if(sqlite3_step(statment)!=SQLITE_DONE){

       NSAssert1(0, @"更新表失败:%s", errorMsg);

    }

   sqlite3_finalize(statment);

   //关闭数据库

   sqlite3_close(database);

}

代码解释:

备注1sqlite3_open():打开数据库

在操作数据库之前,首先要打开数据库。

这个函数打开一个sqlite数据库文件的连接并且返回一个数据库连接对象。

第1个参数:数据文件路径必须用C风格字符串(不能用NSString),[filePath UTF8String]将filePath转换为C风格字符串。

第2个参数:是返回的数据库连接对象。

备注2sqlite3_exec():执行SQL语句

     第1个参数:数据库指针,是前面open函数得到的指针

     第2个参数:const char *sql是一条sql 语句,以\0结尾。

     第3个参数:sqlite3_callback 是回调,当这条语句执行之后,sqlite3会调用这个回调函数。

     第4个参数:void*是一个指针,可以传递任何一个指针参数到这里,这个参数最终会传到回调函数里面,如果不需要传递指针给回调函数,可以填NULL

备注3sqlite3_prepare_v2():将sql文本转换成一个准备语句(prepared statement)对象,同时返回这个对象的指针

    第1个参数:数据库指针,是前面open函数得到的指针

    第2个参数:sql语句,必须是C风格字符串

    第3个参数:如果该参数小于0,则函数取出zSql中从开始到第一个0终止符的内容;如果nByte不是负的,那么它就是这个函数能从zSql中读取的字节数的最大值。如果nBytes非负,zSql在第一次遇见’/000/或’u000’的时候终止

    第4个参数:上面提到zSql在遇见终止符或者是达到设定的nByte之后结束,假如zSql还有剩余的内容,那么这些剩余的内容被存放到pZTail中,不包括终止符

备注4sqlite3_step()

    这个过程用于执行有前面sqlite3_prepare创建的准备语句。这个语句执行到结果的第一行可用的位置。继续前进到结果的第二行的话,只需再次调用sqlite3_setp()。继续调用sqlite3_setp()直到这个语句完成,那些不返回结果的语句(如:INSERT,UPDATE,或DELETE),sqlite3_step()只执行一次就返回

备注5sqlite3_column_text()

    从结果集中获取各列的值,需要注意的是:第一列的索引是0。

备注6sqlite3_finalize()

这个过程销毁前面被sqlite3_prepare创建的准备语句,每个准备语句都必须使用这个函数去销毁以防止内存泄露。

在空指针上调用这个函数没有什么影响,同时可以在准备语句的生命周期的任一时刻调用这个函数:在语句被执行前,一次或多次调用

sqlite_reset之后,或者在sqlite3_step任何调用之后。

备注7sqlite3_close()

         关闭前面使用sqlite3_open打开的数据库连接,任何与这个连接相关的准备语句必须在调用这个关闭函数之前被释放掉。

备注8sqlite3_bind_text()

第1个参数:指向在sqlite3_prepare_v2()调用中使用的sqlite3_stme。

第2个参数:所绑定的变量的索引(sql语句中第一个问号的索引),需要注意的是:第一个问号的索引是1,而不是0。

第3个参数:只有少数绑定函数,比如用于绑定文本或二进制数据的绑定函数,这个参数用来设定传递数据的长度。对于C字符串,可以传递-1来代替字符串的长度,意思是要是要使用整个字符串。

第4个参数:回调函数,一般用于在语句执行后做内存清理相关的工作。可以设置为NULL。

 

### 回答1: Linux下可以使用命令行工具sqlite3来操作SQLite数据库SQLite是一种轻量级的关系型数据库,它的数据存储在单个文件中,非常适合小型项目或嵌入式设备。 要使用sqlite3,首先需要安装它。在Ubuntu或Debian系统中,可以使用以下命令安装: sudo apt-get install sqlite3 安装完成后,可以使用以下命令打开一个SQLite数据库文件: sqlite3 /path/to/database/file.db 在sqlite3命令行中,可以执行SQL语句来创建表、插入数据、查询数据等操作。例如,创建一个名为“users”的表: CREATE TABLE users ( id INTEGER PRIMARY KEY, name TEXT, age INTEGER ); 插入一条数据: INSERT INTO users (name, age) VALUES ('Tom', 25); 查询数据: SELECT * FROM users; 更多操作可以参考SQLite官方文档。 ### 回答2: SQLite3是一种内嵌式的关系型数据库,它拥有小巧灵活、可移植性强的特点,并且在很多平台上都可以使用。常见的Linux操作系统中一般会自带SQLite3,因此我们可以利用这一点轻松地在 Linux 系统中使用 SQLite3 数据库。 首先我们需要在命令行界面下打开 SQLite 命令行工具,这可以通过在终端中输入 sqlite3 命令实现。此时会进入 SQLite3 的 shell 窗口,在这个窗口中,我们可以输入 SQL 语句和 SQLite 提供的命令来操作数据库。 接下来,我们可以创建一个新的数据库文件。可以使用如下命令创建数据库: ``` sqlite3 database.db ``` 这个命令将会在当前目录下创建一个名为 database.db 的 SQLite3 数据库文件。如果指定的文件已经存在,这个命令会直接打开这个数据库文件。 接着,我们可以使用 SQLite3 的语言来执行数据库操作,例如我们可以使用如下命令创建一个名为 users 的表格: ``` CREATE TABLE users ( id INTEGER PRIMARY KEY, name TEXT NOT NULL, age INTEGER NOT NULL ); ``` 在这个命令中,我们首先指定了表的名称为 users,并用括号包含了我们想要存储的每一个字段。我们定义了三个字段,分别是 id、name 和 age。其中,id 字段被定义为 PRIMARY KEY,这意味着它将作为这个表格的主键,确保每一行数据都具备唯一性。而 name 和 age 字段则分别被定义为 TEXT 和 INTEGER 类型,并且我们也为它们定义了 NOT NULL 属性,禁止这两个字段为空值。 我们可以使用 INSERT INTO 语句向 users 表格中添加数据: ``` INSERT INTO users (name, age) VALUES ("Tom", 20); ``` 在这个例子中,我们向 users 表格中添加了一行数据,字段 name 的值为 "Tom",age 的值为 20。我们没有指定 id 字段,因为它是自动生成的。若果我们需要查看 users 表格中的所有数据,可以使用 SELECT * FROM users 命令。 总的来说,SQLite3 是一个功能强大而且简单易用的数据库系统,并且它适用于多种不同的平台。在 Linux 操作系统上,SQLite3 是一个非常好的选择,因为它可以帮助我们轻松地管理和操作一些小型的数据。它还可以通过 Python 和其他语言的 API 来非常简单地实现许多数据操作任务。 ### 回答3: Linux下使用SQLite3数据库是一种比较流行的数据库运用方式,因为SQLite3是一款轻量级的、开源的数据库,数据存储在单一文件中,所以在单个用户下使用SQLite3是非常方便的。 SQLite3的安装过程很简单,只需要通过apt-get命令进行安装即可。在安装完成后,就可以在linux服务器中使用sqlite3命令行进行数据库的管理。 SQLite3的使用可以分为以下几个步骤: 1. 创建数据库 使用sqlite3数据库之前,需要先创建一个数据库文件,可以使用如下的命令创建: $ sqlite3 test.db 2. 创建数据表 使用CREATE TABLE语句可以在数据库中创建数据表,例如: CREATE TABLE users ( id INT PRIMARY KEY, name TEXT, age INT ); 3. 插入数据 插入数据可以使用INSERT INTO语句,例如: INSERT INTO users(id, name, age) VALUES (1, 'Tom', 20); 4. 查询数据 可以使用SELECT语句查询数据,例如: SELECT * FROM users; 5. 更新数据 使用UPDATE语句可以更新数据,例如: UPDATE users SET age = 21 WHERE id = 1; 6. 删除数据 使用DELETE语句可以删除数据,例如: DELETE FROM users WHERE id = 1; SQLite3在使用过程中有许多的优点,比如轻量级、文件型数据库、高性能等等。不过也有些缺点,比如不支持并发访问、不支持存储过程等。所以,如何选择数据库还需要结合具体应用场景来进行选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值