iOS数据库的基本使用

今天总结下数据库的基本使用方法:

iOS使用的数据库一般就是sqlite3,在使用该数据库前一定要先导入数据库框架,否则会出错,接下来引入头文件#import

在工程里创建一个Model类Student,一个数据库工具类DataBaseTool

在Student.h中定义几条属性:

#import

@interface

Student : NSObject

@property(nonatomic,copy)NSString

*name;

@property(nonatomic,copy)NSString

*hobby;

@property(nonatomic,assign)NSInteger

age;

@end

DataBaseTool.h中对数据库操作方法的声明:

#import

#import

#import "Student.h"

@interface DataBaseTool : NSObject

{

//用来保存数据库对象的地址

sqlite3 *dbPoint;

}

//为了保证当前数据库在工程里是唯一的,我们用单例的方式创建一个数据库工具对象

+ (dataBaseTool *)shareDataBaseTool;

//打开数据库

- (void)openDB;

//给数据库创建张表格,table

- (void)createTable;

//插入一个学生信息

- (void)insertStu:(Student *)stu;

//更新一个学生信息

- (void)updateStu:(Student *)stu;

//删除操作

- (void)deletedateStu:(Student

*)stu;

//查询操作

- (NSMutableArray *)selectAllStu;

//关闭数据库

- (void)closeDB;

@end

DataBaseTool.m中实现方法:

#import "dataBaseTool.h"

@implementation dataBaseTool

+ (dataBaseTool *)shareDataBaseTool{

static dataBaseTool *tool;

static dispatch_once_t oneToken;

dispatch_once(&oneToken, ^{

tool=[[dataBaseTool alloc]

init];

});

return tool;

}

- (void)openDB{

//数据库文件也保存在沙盒的documents文件里,所以先找沙盒路径

NSArray

*sandBox=NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,

NSUserDomainMask, YES);

NSString

*sandBoxPath=sandBox[0];

//拼接文件路径,如果系统根据这个文件路径查找的时候有对应文件则直接打开数据库,如果没有则会创建一个相应的数据库

NSString *documentPath=[sandBoxPath

stringByAppendingPathComponent:@"Student.sqlite"];

int result=sqlite3_open([documentPath

UTF8String], &dbPoint);

if (result==SQLITE_OK) {

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

NSLog(@"%@",documentPath);

}else{

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

}

}

- (void)createTable{

//primary key

是主键的意思,主健在当前表里数据是唯一的,不能重复,可以唯一标识一条数据,一般是整数

//autoincrement自增,为了让主键不重复,会让主键采用自增的方式

//if not exists

如果没有表才会创建,防止重复创建覆盖之前数据

//数据库问题90%是sql语句问题,所以先保证语句没问题,再放到工程里使用

NSString *sqlStr=@" create table if not

exists stu(number integer primary key autoincrement,name text,age integer,hobby

text)";

//执行这条sql语句

int result=sqlite3_exec(dbPoint, [sqlStr

UTF8String], nil, nil, nil);

if (result==SQLITE_OK) {

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

}else{

NSLog(@"表创建失败");

}

}

- (void)insertStu:(Student *)stu{

NSString *sqlStr=[NSString

stringWithFormat:@"insert into stu (name,age,hobby) values

('%@','%ld','%@')",stu.name,stu.age,stu.hobby

];

//执行sql语句

int result=sqlite3_exec(dbPoint, [sqlStr

UTF8String], nil, nil, nil);

if (result==SQLITE_OK) {

NSLog(@"添加学生成功");

}else {

NSLog(@"添加学生失败");

}

}

- (void)updateStu:(Student *)stu{

NSString *sqlStr= [NSString

stringWithFormat:@"update stu set hobby='%@',age=%ld where

name='%@'",stu.hobby,stu.age,stu.name];

//执行sql语句

int result=sqlite3_exec(dbPoint, [sqlStr

UTF8String], nil, nil, nil);

if (result==SQLITE_OK) {

NSLog(@"更新成功");

}else{

NSLog(@"更新失败");

NSLog(@"%d",result);

}

}

- (void)deletedateStu:(Student

*)stu{

NSString *sqlStr=[NSString

stringWithFormat:@"delete from stu where name='%@'",stu.name];

//执行sql语句

int result=sqlite3_exec(dbPoint, [sqlStr

UTF8String], nil, nil, nil);

if (result==SQLITE_OK) {

NSLog(@"删除成功");

}else{

NSLog(@"删除失败");

}

}

- (NSMutableArray *)selectAllStu{

//查询逻辑

//1.先从本地的数据库中读取某张表里的所有数据

//2.然后逐条进行读取,对model进行赋值

//3.把已经赋值好得model放到数组中,并且返回

NSString *sqlStr=@"select * from

stu";

//在语句里*是通配符的意思,通过一个*相当于代替了表里的所有的字段名

//接下来需要定义一个跟随指针,它用来遍历数据库表中的每行数据

//第三个参数:查询语句字数限制,-1是没有限制

sqlite3_stmt *stmt=nil;

int result=sqlite3_prepare_v2(dbPoint,

[sqlStr UTF8String], -1, &stmt, nil);

//这个方法相当于把数据库和跟随指针关联,一同完成查询功能

//初始化一个用来装学生的数组

NSMutableArray *stuArr=[NSMutableArray

array];

if (result==SQLITE_OK) {

NSLog(@"查询成功");

//开始遍历查询数据库的每一行数据

while (sqlite3_step(stmt)==SQLITE_ROW)

{

//让跟随指针进行遍历查询,如果没有行,才会停止循环

//满足条件,则逐列的读取内容

//第二个参数表示当前这列数据在表的第几列

const unsigned char

*name=sqlite3_column_text(stmt, 1);

int age=sqlite3_column_int(stmt,

2);

const unsigned char

*hobby=sqlite3_column_text(stmt,3);

//把列里的数据再进行类型的转换

NSInteger stuAge=age;

NSString *stuName=[NSString

stringWithUTF8String:(const char *)name];

NSString *stuHobby=[NSString

stringWithUTF8String:(const char *)hobby];

//给对象赋值,然后把对象放到数组里

Student *stu=[[Student alloc]

init];

stu.name=stuName;

stu.hobby=stuHobby;

stu.age=stuAge;

[stuArr addObject:stu];

[stu release];

}

}else{

NSLog(@"查询失败");

NSLog(@"%d",result);

}

return stuArr;

}

- (void)closeDB{

int

result=sqlite3_close(dbPoint);

if (result==SQLITE_OK) {

NSLog(@"数据库关闭成功");

// NSLog(@"%@",documentPath);

}else{

NSLog(@"数据库关闭失败");

}

}

@end

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352

推荐阅读更多精彩内容