- 浏览: 2965892 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (893)
- android (110)
- iphone (198)
- java (79)
- JavaScript手册-目录 (9)
- JavaScript手册-Array (19)
- JavaScript手册-Boolean (5)
- JavaScript手册-Date (50)
- JavaScript手册-Math (30)
- JavaScript手册-Number (14)
- JavaScript手册-RegExp (7)
- JavaScript手册-String (38)
- JavaScript手册-全局函数 (8)
- JavaScript实用脚本 (7)
- Others (21)
- java-jpcap (7)
- java-thread (1)
- ibm文章 (3)
- classloader (2)
- java-filter (2)
- 运行环境 (33)
- java-正则 (2)
- oracle (1)
- linux-shell (26)
- wap (1)
- sqlite (3)
- wow (1)
- jvm (1)
- git (5)
- unity3d (29)
- iap (2)
- mysql (23)
- nginx (14)
- tomcat (9)
- apache (2)
- php (1)
- ubuntu (40)
- rsa (1)
- golang (21)
- appstore (5)
- sftp (2)
- log4j (2)
- netty (18)
- 测试工具 (6)
- memcache (5)
- 设计模式 (1)
- centos (8)
- google_iab (5)
- iOS专题 (4)
- mac (10)
- 安装配置帮助手册 (2)
- im4java_graphicsmagick (5)
- inotify-tools (1)
- erlang (6)
- 微信支付 (1)
- redis (8)
- RabbitMQ (5)
最新评论
-
heng123:
Netty视频教程https://www.douban.com ...
netty4.0.23 初学的demo -
maotou1988:
使用Netty进行Android与Server端通信实现文字发 ...
netty4.0.23 初学的demo -
码革裹尸:
非常感谢,正好用上
android 呼入电话的监听(来电监听) -
rigou:
提示的/222.177.4.242 无法链接到ip地址,是什 ...
通过 itms:services://? 在线安装ipa ,跨过app-store -
duwanbo:
GridView与数据绑定
iphone开发中sqlite3的操作说明(转载)
转载地址 : http://www.cnblogs.com/growing/archive/2012/02/16/2353637.html
ibsqlite3.0.dylib文件地址:
/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS2.2.sdk/usr/lib/libsqlite3.0.dylib
2,代码中的操作:
那么接下来是代码了。
1 首先获取iPhone上sqlite3 的数据库文件的地址
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *path = [documentsDirectory stringByAppendingPathComponent:@"database_name"];
2 打开 iPhone上的sqlite3 的数据库 文件
sqlite3 *database;
sqlite3_open([path UTF8String], &database);
3 准备sql文---sql语句
sqlite3_stmt *stmt;
const char *sql = "SELECT * FROM table_name WHERE pk=? and name=?
";
sqlite3_prepare_v2(database, sql
, -1, &stmt, NULL);
4 邦定参数
// 邦定第一个int参数
sqlite3_bind_int(stmt, 1, 1);
// 邦定第二个字符串参数
sqlite3_bind_text(stmt, 2, [title UTF8String], -1, SQLITE_TRANSIENT);
5 执行 sql文
sqlite3_step(stmt);
6 释放sql文资源
sqlite3_finalize(stmt);
7 关闭i Phone上的sqlite3 的数据库
sqlite3_close(database);
以下演示一下使用sqlite的步骤,先创建一个数据库,然后查询其中的内容。2个重要结构体和5个主要函数: sqlite3 *pdb, 数据库句柄,跟文件句柄FILE很类似 sqlite3_stmt *stmt, 这个相当于ODBC的Command对象,用于保存编译好的SQL语句 sqlite3_open(), 打开数据库 sqlite3_exec(), 执行非查询的sql语句 sqlite3_prepare(), 准备sql语句,执行select语句或者要使用parameter bind时,用这个函数(封装了sqlite3_exec). Sqlite3_step(), 在调用sqlite3_prepare后,使用这个函数在记录集中移动。 Sqlite3_close(), 关闭数据库文件 还有一系列的函数,用于从记录集字段中获取数据,如 sqlite3_column_text(), 取text类型的数据。 sqlite3_column_blob(),取blob类型的数据 sqlite3_column_int(), 取int类型的数据 PreparedStatement方式处理SQL请求的过程 特点:可以绑定参数,生成过程。执行的时候像是ADO一样,每次返回一行结果。 1. 首先建立statement对象: int sqlite3_prepare( sqlite3 *db, /* Database handle */ const char *zSql, /* SQL statement, UTF-8 encoded */ int nBytes, /* Length of zSql in bytes. */ sqlite3_stmt **ppStmt, /* OUT: Statement handle */ const char **pzTail /* OUT: Pointer to unused portion of zSql */ ); 2. 绑定过程中的参数(如果有没有确定的参数) int sqlite3_bind_xxxx(sqlite3_stmt*, int, ...); 第二个int类型参数-表示参数的在SQL中的序号(从1开始)。 第三个参数为要绑定参数的值。 对于blob和text数值的额外参数: 第四参数是字符串(Unicode 8or16)的长度,不包括结束'\0'。 第五个参数,类型为void(*)(void*),表示SQLite处理结束后用于清理参数字符串的函数。 没有进行绑定的未知参数将被认为是NULL。 3. 执行过程 int sqlite3_step(sqlite3_stmt*); 可能的返回值: *SQLITE_BUSY: 数据库被锁定,需要等待再次尝试直到成功。 *SQLITE_DONE: 成功执行过程(需要再次执行一遍以恢复数据库状态) *SQLITE_ROW: 返回一行结果(使用sqlite3_column_xxx(sqlite3_stmt*,, int iCol)得到每一列的结果。 再次调用将返回下一行的结果。 *SQLITE_ERROR: 运行错误,过程无法再次调用(错误内容参考sqlite3_errmsg函数返回值) *SQLITE_MISUSE: 错误的使用了本函数(一般是过程没有正确的初始化) 4. 结束的时候清理statement对象 int sqlite3_finalize(sqlite3_stmt *pStmt); 应该在关闭数据库之前清理过程中占用的资源。 5. 重置过程的执行 int sqlite3_reset(sqlite3_stmt *pStmt); 过程将回到没有执行之前的状态,绑定的参数不会变化。 其他工具函数 1. 得到结果总共的行数 int sqlite3_column_count(sqlite3_stmt *pStmt); 如果过程没有返回值,如update,将返回0 2. 得到当前行中包含的数据个数 int sqlite3_data_count(sqlite3_stmt *pStmt); 如果sqlite3_step返回SQLITE_ROW,可以得到列数,否则为零。 3. 得到数据行中某个列的数据 sqlite3_column_xxx(sqlite3_stmt*, int iCol); 在sqlite3_step返回SQLITE_ROW后,使用它得到第iCol列的数据。 其中的xxx代表: blob:指向保存数据内存的指针 bytes, bytes16: 得到该blob类型数据的大小,或者text转换为UTF8/UTF16的字符串长度。 double, int, int64: 数值 text,text16:字符串指针 type:该列的数据类型(SQLITE_INTEGER,SQLITE_FLOAT,SQLITE_TEXT,SQLITE_BLOB,SQLITE_NULL) 注意:如果对该列使用了不同与该列本身类型适合的数据读取方法,得到的数值将是转换过的结果。 4. 得到数据行中某个列的数据的类型 int sqlite3_column_type(sqlite3_stmt*, int iCol); 返回值:SQLITE_INTEGER,SQLITE_FLOAT,SQLITE_TEXT,SQLITE_BLOB,SQLITE_NULL 使用的方法和sqlite3_column_xxx()函数类似。
发表评论
-
iOS程序运行生命周期
2015-11-10 09:05 966iOS程序运行生命周期 在文件AppDele ... -
iOS开发系列--IOS程序开发概览
2015-11-10 07:32 1181iOS开发系列--IOS程序开发概览 概览 ... -
2015年11月Xcode7.1(7B91b)打包发布苹果iOS应用指南
2015-11-09 18:29 108812015年11月Xcode7.1(7B91b) ... -
self.navigationController pushViewController执行不成功
2015-11-06 08:28 1613self.navigationControlle ... -
ios NSString format 保留小数点 float double
2015-11-05 17:37 2934ios NSString format 保留小数点 f ... -
自定义 URL Scheme 完全指南
2015-11-04 16:21 904自定义 URL Scheme 完全指南 转载 htt ... -
UIViewController生命周期方法viewDidLoad、viewWillAppear和viewDidAppear
2015-11-01 12:29 2954UIViewController生命周期 ... -
关于self.view.window与viewDidLoad、viewWillAppear、viewDidAppear
2015-11-01 09:36 2541关于self.view.window与viewD ... -
UIScreen学习记录
2015-10-31 08:18 1061UIScreen学习记录 转载自 ... -
使用NSTimer和CGAffineTransformMakeRotation实现旋转动画
2015-10-29 11:53 1826使用NSTimer和CGAffineTransform ... -
【原】iOSCoreAnimation动画系列教程(一):CABasicAnimation【包会】
2015-10-29 08:59 1026【原】iOSCoreAnimation动 ... -
iOS 在UILabel显示不同的字体和颜色
2015-10-27 08:07 1558在项目开发中,我们经常会遇到在这样一种情形:在一个UI ... -
UISlider滑动条的属性介绍以及于标签联合使用实时显示变动值
2015-10-27 08:06 1255UISlider滑动条的属性 ... -
关于使用DSLTableView下拉刷新数据遇到的问题
2015-10-23 21:17 943关于使用DSLTableView下 ... -
使用AdSupport.framework生成IDFA唯一标识符
2015-10-23 17:29 4709使用AdSupport.framework生成IDFA ... -
AppDelegate的详解
2015-10-22 17:51 680AppDelegate的详解 ... -
iOS开发问题集锦
2015-10-22 13:06 5291. Xcode开发连真机运行报错Please ver ... -
iOS 对象属性参数名定义的注意事项不能以alloc,new,copy,mutableCopy 作为开头命名
2015-10-21 15:41 1327property's synthesized g ... -
iOS-自定义的画圆或弧的UIView
2015-10-21 14:20 2655iOS-自定义的画圆或弧的UIView Cu ... -
iOS自定义的模态提示对话框
2015-10-20 14:27 6477iOS自定义的模态提示对话框 基本思路: 1.创建 ...
相关推荐
在iPhone中简单应用Sqlite3.0数据库,实现创建表,初始化数据,带参查询,简单查询,以及插入数据信息。
iPhone手机开发中运用sqlite3的使用案例 教程,恕时间限制不能给出说明,以后可以
iphone开发SQLite数据库使用 简单方便
自行整理的用Lazarus进行SQLite3开发的入门教程。
源码调用sqlite3.dll接口API实现SQLite3数据库操作。Tags:sqlite3。
使用VS 2015开发sqlite3和MFC示例程序。 该程序的作用是将一些做过的题目保存到SQLITE3数据库中,可以在将来用作复习。 程序可以往SQLITE3数据库中添加数据(包括图片数据),删除,修改,查询。
SQLite3基本数据库操作
关于Sqlite的所有操作已经单独创建了专门的跨平台【.NETCore3.1】类库包含相应的帮助类,可以直接生成后拿到任何项目中直接使用,高效简单,省去了从头开发Sqlite数据库的时间,将更多的精力用于业务内容;...
sqlite3基本操作 详细介绍sqlite 的基本语法
cgi c语言中sqlite3的使用,调用sqlite3的api完成数据库的操作。
sqlite3 64位 开发sdk,包含sqlite3.h sqlite3.lib sqlite3.dll 3个文件
介绍node-sqlite3 API,并对API初步封装,方便开发人员调用,实现业务逻辑。
sqlite3命令行使用说明,可以使用dos命令在命令行下进行sqlite3数据库的操作
Sqlite3 C++ 简单单例数据库操作类封装,支持数据的简单操作,可用,尚不完善
sqlite3命令方式操作大全
SQLite3开发SQL详解 库表结构图形工具 SQLite SQL语法
最新的sqlite3开发包
包括如下版本: sqlite3,sqlite3_armv6,sqlite3_armv6-nofpu, sqlite3_armv7, sqlite3_armv7-pie
VC中使用sqlite SQLite官方下载只提供给我们一个sqlite3.dll...将sqlite3.lib加入到工程链接中,Project->Settings,Link选项卡,Object/library modules最后添入sqlite3.lib D:\sqlitedll-3_6_23里有.dll和.def文件
这是一个完整的eclipse项目,可以作为初学者使用学习