这篇文章主要讲IOS 中Sqlite3数据库的简单介绍和基本的增删改插,目前已经有了FMDB等封装好的第三方,为什么还要学习sqlite3数据呢,个人觉得只有掌握了数据库的基本操作和语法才能更好的掌握和运用其他的第三方。
SQLite?
- SQLit是一个开源、轻型嵌入式关系数据库,诞生于2000年5月
- 占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了
- 能够支持Windows/Linux/Unix等等主流的操作系统
- 比起Mysql、PostgreSQL这两款开源的世界著名数据库管理系统来讲,它的处理速度比他们都快
SQL语句常用操作
增、删、改、查,CRUD,Create[新建], Retrieve[检索], Update[更新], Delete[删除]。
SQL语法写法特点
1、不区分大小写(CREATE = create)
2、每条语句以分号(;)结尾
3、关键字建议大写
SQL语句常用关键字
select、insert、update、delete、from、create、where、desc、order、by、group、table、alter、view、index等
- 数据定义语句(DDL):包括create和drop等操作,在数据库中创建新表或删除表(create table或 drop table)
- 数据操作语句(DML):包括insert、update、delete等操作,分别用于添加、修改、删除表中的数据
- 数据查询语句(DQL):可以用于查询获得表中的数据,关键字select是DQL(也是所有SQL)用得最多的操作,其他DQL常用的关键字有where,order by,group by和having
要使用Sqlite之前必须先导入libsqlite3.tbd库然后导入头文件
#import <sqlite3.h>
@interface ViewController (){
sqlite3 *_db;
}
数据库的基本使用-打开数据库和创建表
//1.获取沙盒文件名
NSString *fileName = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"student.sqlite"];
NSLog(@"fileName = %@",fileName);
//2.创建(打开)数据库 (如果数据库不存在,会自动创建)
int result = sqlite3_open(fileName.UTF8String, &_db);
/*代码解析:sqlite3_open()将根据文件路径打开数据库,如果不存在,则会创建一个新的数据库。如果result等于常量SQLITE_OK,则表示成功打开数据库
sqlite3 *db:一个打开的数据库实例
数据库文件的路径必须以C字符串(而非NSString)传入*/
if (result == SQLITE_OK) {
NSLog(@"成功打开数据库");
//创表(这里以创建一个学生表为例,学生包含姓名和年龄,id integer primary key auto increment 为学生表的主键,并且会更具学生数据条数的增加而自动增加)
const char *sql = "create table if not exists t_student (id integer primary key autoincrement, name text, age integer);";
char *errorMesg = NULL; // 用来存储错误信息
//sqlite3_exec()可以执行任何SQL语句,比如创表、更新、插入和删除操作。但是一般不用它执行查询语句,因为它不会返回查询到的数据
int result = sqlite3_exec(_db, sql, NULL, NULL, &errorMesg);
if (result == SQLITE_OK) {
NSLog(@"成功创建t_student表");
}else {
NSLog(@"创建 t_student失败:%s",errorMesg);
}
}else {
NSLog(@"打开数据库失败");
}
插入数据
//插入100条学生的数据
for (int i = 0; i < 30; i++) {
StudentModel *student = [[StudentModel alloc] init];
student.name = [NSString stringWithFormat:@"Jacl-%d",arc4random()%100];
student.age = arc4random()%100;
//插入语句(insert into 表名(字段1,字段2,..)values (字段1值,字段2值,..);)
NSString *sql = [NSString stringWithFormat:@"insert into t_student (name,age) values ('%@',%d);",student.name,student.age];
char *errorMesg = NULL;
int result = sqlite3_exec(_db, sql.UTF8String, NULL, NULL, &errorMesg);
if (result == SQLITE_OK) {
NSLog(@"添加数据成功");
}else {
NSLog(@"添加数据失败");
}
}
查询数据
//定义一个储存查询结果的数组
NSMutableArray *students = nil;
//1.定义sql语句(查询所有学生的数据)
const char *sql = "select id, name, age from t_student;";
//也可用where条件查询语句,查询年龄大于60的学生年龄
const char *sql = "select id, name, age from t_student where age > 60;";
//2.定义一个stmt存放结果集
sqlite3_stmt *stmt = NULL;
//3.检测SQL语句的合法性
int result = sqlite3_prepare_v2(_db, sql, -1, &stmt, NULL);
if (result == SQLITE_OK) {
NSLog(@"查询语句合法");
students = [NSMutableArray array];
//4.执行SQL语句
while (sqlite3_step(stmt) == SQLITE_ROW) {
StudentModel *student = [[StudentModel alloc] init];
//获得第几条的id
student.ID = sqlite3_column_int(stmt, 0);
//获得第几条的name
const unsigned char *sname = sqlite3_column_text(stmt, 1);
student.name = [NSString stringWithUTF8String:(const char *)sname];
//获得第几条的age
student.age = sqlite3_column_int(stmt, 2);
NSLog(@"%d %@ %d",student.ID,student.name, student.age);
[students addObject:student];
}
} else {
NSLog(@"查询语句非法");
}
修改数据
//其实Sqlite的数据插入,修改,删除执行的方法都是一样的只是执行的sql语句不一样,想知道sql的更多语句操作自行百度了,比较多这里就不讲解了,只介绍一些基本的操作方法。
//sqlite3数据(把年龄大于60的学生名字全部改成‘哈哈’)
NSString *sql = @"update t_student set name = '哈哈' where age > 60";
char *errorMesg = NULL;
int result = sqlite3_exec(_db, sql.UTF8String, NULL, NULL, &errorMesg);
if (result == SQLITE_OK) {
NSLog(@"更改成功");
}else {
NSLog(@"更改失败");
}
//然后执行查询语句就能看到更改后的效果了
删除数据
//删除表中年龄大于60的学生数据
NSString *sql = @"delete from t_student where age >= 60";
char *errorMesg = NULL;
int result = sqlite3_exec(_db, sql.UTF8String, NULL, NULL, &errorMesg);
if (result == SQLITE_OK) {
NSLog(@"删除成功");
}else {
NSLog(@"删除失败");
}
数据库的基本使用就讲解到这里,这里推荐一个比较好用的第三方FMDB,比起Core Data本人更喜欢用FMDB。有兴趣的可以自行研究下,后面我会写一篇FMDB三方的基本使用的文章,写得有误的地方欢迎各位指正。