iOS- SQLite3的基本使用
- iOS- 简单说说iOS移动客户端SQLite3的基本使用
- 1.为什么要使用SQLite3?
-
•大量数据需要存储•管理数据,存储数据SQLite是一种关系型数据库(也是目前移动客户端的主流数据库)2.SQLite3的几种存储类型a.NULL: 表示该值为NULL值b.INTEGER: 无符号整型值c.REAL: 浮点值d.TEXT: 文本字符串e.BLOB: 二进制数据(比如文件)•实际上SQLite是无类型的,建表时声明或不声明类型都可以,也就意味着创表语句可以这么写:create table t_student(name, age);但为了保持良好的编程规范,方便程序员之间的交流,编写建表语句的时候最好加上每个字段的具体类型3.SQLite3的具体实现3.1•在iOS中要使用SQLite3,需要添加库文件:libsqlite3.dylib并导入主头文件,这是一个C语言的库3.2创建数据库(sqlite3_opendb)复制代码1 // 设置沙盒中的文件路径2 // 提示:在自己开发中,不要用.db结尾的sqlite数据库文件名3 NSString *dbPath = [@"readme.db" appendDocumentDir];4 NSLog(@"%@", dbPath);56 /**7 sqlite3_open89 1) 如果数据库存在,直接打开10 2) 如果数据库不存在,先创建数据库文件,再打开11 */12 _db = NULL;1314 if (SQLITE_OK == sqlite3_open([dbPath UTF8String], &_db)) {15 NSLog(@"数据库打开成功");16 } else {17 NSLog(@"数据库打开失败");18 }复制代码3.31.单步执行操作(sqlite3_exec)复制代码#pragma mark 单步执行SQL- (void)execSQL:(NSString *)sql message:(NSString *)message{// 执行SQL语句char *errmsg = NULL;if (SQLITE_OK == sqlite3_exec(_db, [sql UTF8String], NULL, NULL, &errmsg)) {NSLog(@"%@成功!", message);} else {// C语言中字符串输出应该用%sNSLog(@"%@失败 - %s", message, errmsg);}}复制代码2.创建数据表复制代码1 // 1. 检查沙盒,判断数据库文件是否存在,如果存在就不再建表;2 // 2. 数据库的方法:IF NOT EXISTS,放在表名之前即可3 // 定义SQL语句4 NSString *sql = @"CREATE TABLE IF NOT EXISTS T_Person (id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, name TEXT, gender INTEGER, age INTEGER, height REAL)";56 [self execSQL:sql message:@"创建数据表"];复制代码4.插入数据1 // 1. SQL2 NSString *sql = [NSString stringWithFormat:@"INSERT INTO T_Person (name, gender, age, height) VALUES ('%@', %d, %d, %f)", person.name, person.gender, person.age, person.height];34 [self execSQL:sql message:@"新增个人记录"];5.更新数据复制代码1 //修改2 - (void)updatePerson:(Person *)person{345 NSString *sql = [NSString stringWithFormat:@"update t_Person set name = '%@' where id=%d",person.name,person.ID];67 [self execSQL:sql msg:@"修改"];89 }复制代码6.删除数据复制代码1 //删除2 - (void)removePerson:(NSInteger)personID{345 NSString *sql = [NSString stringWithFormat:@"delete from t_Person where id=%d",personID];67 [self execSQL:sql msg:@"删除"];89 }复制代码7.查询操作–sqlite3_prepare_v2检查sql的合法性–sqlite3_step逐行获取查询结果–sqlite3_coloum_xxx获取对应类型的内容–sqlite3_finalize释放stmt复制代码1 // 1. SQL2 NSString *sql = @"SELECT id, name, age, gender, height FROM T_Person";34 // 2. 查询语句通常是使用字符串拼接出来的5 // 因此,在正常使用查询语句之前,需要检查SQL语句的语法正确!6 sqlite3_stmt *stmt = NULL;78 if (SQLITE_OK == sqlite3_prepare_v2(_db, [sql UTF8String], -1, &stmt, NULL)) {9 NSLog(@"语法正确");10 // 利用句柄,逐一查询符合条件的数据11 // sqlite3_step 每次提取一条查询的记录行,不断重复,一直取到最后一条记录位置12 while (SQLITE_ROW == sqlite3_step(stmt)) {13 // 取到行信息,逐一获取每一列的内容14 // iCol对应的就是SQL语句中字段的顺序,从0开始15 // 根据实际查询字段的属性,使用sqlite3_column_xxx取得对应的内容即可16 int ID = sqlite3_column_int(stmt, 0);17 const unsigned char *name = sqlite3_column_text(stmt, 1);18 int age = sqlite3_column_int(stmt, 2);19 int gender = sqlite3_column_int(stmt, 3);20 CGFloat height = sqlite3_column_double(stmt, 4);2122 // const unsigned char *直接输出看不出结果,需要转换23 NSString *nameUTF8 = [NSString stringWithUTF8String:(const char *)name];2425 Person *p = [Person personWithID:ID name:nameUTF8 age:age gender:gender height:height];2627 NSLog(@"%@", p);28 }29 } else {30 NSLog(@"语法错误");31 }复制代码
iOS- SQLite3的基本使用的更多相关文章
- iOS sqlite3 的基本使用(增 删 改 查)
iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...
- iOS sqlite3数据库解析
看来从版本3.3.1基本上已经支持线程句柄的传递功能.具体限制我标记了一下.(6) Is SQLite threadsafe?SQLite is threadsafe. We make this co ...
- iOS Sqlite3 Demo 及 FMDB Demo
本文是主要实现了三个函数: testSQLite3 是测试系统自带的sqlite3的demo testFMDB是测试FMDB存取简单的数据类型的 的demo testFMDB2是将任意对象作为一个整体 ...
- ios sqlite3的简单使用
第一:创建表格 //创建表格 -(void)creatTab{ NSString*creatSQL=@"CREATE TABLE IF NOT EXISTS PERSIONFO(ID INT ...
- iOS——sqlite3的使用(iOS嵌入式关系数据库)
1>添加sqlite3动态库:libsqlite3.dylib,CoreGraphics.framework,UIKit.framework,Foundation.framework 2> ...
- iOS SQLite3的使用
1.创建可修改的数据库文件 //应用包内的内容是不可写的,所以需要把应用包内的数据库拷贝一个副本到资源路径去 - (void)createEditableDatabase{ BOOL success; ...
- iOS FMDB的使用(增,删,改,查,sqlite存取图片)
iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...
- iOS数据持久化-OC
沙盒详解 1.IOS沙盒机制 IOS应用程序只能在为该改程序创建的文件系统中读取文件,不可以去其它地方访问,此区域被成为沙盒,所以所有的非代码文件都要保存在此,例如图像,图标,声音,映像,属性列表,文 ...
- iOS 数据存储之SQLite3的使用
SQLite3是iOS内嵌的数据库,SQLite3在存储和检索大量数据方面非常有效,它使得不必将每个对象都加到内存中.还能够对数据进行负责的聚合,与使用对象执行这些操作相比,获得结果的速度更快. SQ ...
- IOS 使用wxsqlite3为sqlite3数据库加密
1,下载wxsqlite3 地址http://jaist.dl.sourceforge.net/project/wxcode/Components/wxSQLite3/wxsqlite3-3.1.1. ...
随机推荐
- ACM之递推递归
Hdu 2569 突破蝙蝠的包围,yifenfei来到一处悬崖面前,悬崖彼岸就是前进的方向,好在现在的yifenfei已经学过御剑术,可御剑轻松飞过悬崖. 现在的问题是:悬崖中间飞着很多红,黄,蓝三种 ...
- ACM之最短路径做题笔记与记录
在这里纪念一下从4月开始一直因为事情而荒废了的最短路,多亏了jbb的帮助,我才完成了FZU热身赛一题简单的一个用模拟链表存边以及最短路径的学习,目前(6.5)已经学会使用了最简单的djstral与sp ...
- 使用WSAIoctl获取socket扩展函数(如AcceptEx)的指针
未获取函数指针就调用函数(如直接连接mswsock.lib并直接调用AcceptEx)的消耗是很大的,因为AcceptEx 实际上是存在于Winsock2结构体系之外的.每次应用程序常试在服务提供层上 ...
- UI进阶 文件管理器(NSFileManager)文件对接器(NSFileHandle)
一.文件管理器与文件连接器之间的区别 文件管理器(NSFileManager) 此类主要是对文件进行的操作(创建/删除/改名等)以及文件信息的获取. 文件连接器(NSFileHandle) 此类主要是 ...
- [SQL]sql语句bug
sql语句格式必须严格检查,一个空格的错误都会导致执行错误. 常见有 1:字符串的值要用 ‘ ’ 括起来 2:用 , 分隔语句段 3:切记判断条件前有一空格:eg:这里最容易出错 4:属性名是否 ...
- Delphi ThreadPool 线程池(Delphi2009以上版本适用)
http://blog.sina.com.cn/s/blog_6250a9df0101kref.html 在网上查找Delphi线程池,结果发现寥寥无几. 看了半天源代码,弄得一头雾水,觉得不容易理解 ...
- Delphi Interfaces
http://www.delphibasics.co.uk/Article.asp?Name=Interface The reason for interfaces Classes that ex ...
- Codeforces Round #339 (Div. 2) B. Gena's Code 水题
B. Gena's Code 题目连接: http://www.codeforces.com/contest/614/problem/B Description It's the year 4527 ...
- hihocoder #1178 : 计数 暴力
#1178 : 计数 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://hihocoder.com/problemset/problem/1178 ...
- cdoj 1150 排名表 拓扑排序
排名表 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1150 Descrip ...