Java代码

  1. -(void) addObserver{
  2. //当程序进入后台时执行操作
  3. UIApplication *app = [UIApplication sharedApplication];
  4. [[ NSNotificationCenter defaultCenter] addObserver: self
  5. selector:@selector(appwillresignActive) name:UIApplicationWillResignActiveNotification object:app];
  6. }
  7. -(void) appwillresignActive{
  8. NSLog(@"监听测试");
  9. }

-(void) addObserver{

//当程序进入后台时执行操作

UIApplication *app = [UIApplication sharedApplication];

[[ NSNotificationCenter defaultCenter] addObserver: self

selector:@selector(appwillresignActive) name:UIApplicationWillResignActiveNotification object:app];

}

-(void) appwillresignActive{

NSLog(@"监听测试");

}

头部引入

Java代码

  1. #import "sqlite3.h"

#import "sqlite3.h"

Java代码

  1. -(void) makeDBinfo{
  2. NSArray *documentsPaths=NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
  3. NSString *databaseFilePath=[[documentsPaths objectAtIndex:0] stringByAppendingPathComponent:@"mydb"];
  4. char *errorMsg;
  5. //打开或创建数据库
  6. sqlite3 *database;
  7. if (sqlite3_open([databaseFilePath UTF8String], &database)!=SQLITE_OK) {
  8. sqlite3_close(database);
  9. }else {
  10. NSLog(@"open sqlite db ok.");
  11. }
  12. //创建数据库表
  13. const char *createSql=" create table if not exists persons (id integer primary key autoincrement,name text)";
  14. if (sqlite3_exec(database, createSql, NULL, NULL, &errorMsg)==SQLITE_OK)
  15. {
  16. NSLog(@"create table ok.");
  17. }else
  18. {
  19. //如果在多个地方使用errorMsg,那么每次使用完毕要清空一下字串,比如这样:
  20. NSLog(@"error: %s",errorMsg);
  21. sqlite3_free(errorMsg);
  22. }
  23. // 向表中插入记录
  24. const char *insertSql="insert into persons (name) values(\"张三\")";
  25. if (sqlite3_exec(database, insertSql, NULL, NULL, &errorMsg)==SQLITE_OK)
  26. {
  27. NSLog(@"insert ok.");
  28. }else
  29. {
  30. //如果在多个地方使用errorMsg,那么每次使用完毕要清空一下字串,比如这样:
  31. NSLog(@"error: %s",errorMsg);
  32. sqlite3_free(errorMsg);
  33. }
  34. //结果集的查询,需要用到statement:
  35. const char *selectSql="select id,name from persons where name = ? ";
  36. sqlite3_stmt *statement;
  37. if (sqlite3_prepare_v2(database, selectSql, -1, &statement, nil)==SQLITE_OK) {
  38. NSLog(@"select ok.");
  39. sqlite3_bind_text(statement, 1, "张三",-1,NULL);
  40. while (sqlite3_step(statement)==SQLITE_ROW) {
  41. int _id=sqlite3_column_int(statement, 0);
  42. NSString *name=[[NSString alloc] initWithCString:(char *)sqlite3_column_text(statement, 1) encoding:NSUTF8StringEncoding];
  43. NSLog(@"row>>id %i, name %@",_id,name);
  44. }
  45. sqlite3_finalize(statement);
  46. }
  47. sqlite3_close(database);
  48. }

-(void) makeDBinfo{

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

NSString *databaseFilePath=[[documentsPaths objectAtIndex:0] stringByAppendingPathComponent:@"mydb"];

char *errorMsg;

//打开或创建数据库

sqlite3 *database;

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

sqlite3_close(database);

}else {

NSLog(@"open sqlite db ok.");

}

//创建数据库表

const char *createSql=" create table if not exists persons (id integer primary key autoincrement,name text)";

if (sqlite3_exec(database, createSql, NULL, NULL, &errorMsg)==SQLITE_OK)

{

NSLog(@"create table ok.");

}else

{

//如果在多个地方使用errorMsg,那么每次使用完毕要清空一下字串,比如这样:

NSLog(@"error: %s",errorMsg);

sqlite3_free(errorMsg);

}

// 向表中插入记录

const char *insertSql="insert into persons (name) values(\"张三\")";

if (sqlite3_exec(database, insertSql, NULL, NULL, &errorMsg)==SQLITE_OK)

{

NSLog(@"insert ok.");

}else

{

//如果在多个地方使用errorMsg,那么每次使用完毕要清空一下字串,比如这样:

NSLog(@"error: %s",errorMsg);

sqlite3_free(errorMsg);

}

//结果集的查询,需要用到statement:

const char *selectSql="select id,name from persons where name = ? ";

sqlite3_stmt *statement;

if (sqlite3_prepare_v2(database, selectSql, -1, &statement, nil)==SQLITE_OK) {

NSLog(@"select ok.");

sqlite3_bind_text(statement, 1, "张三",-1,NULL);

while (sqlite3_step(statement)==SQLITE_ROW) {

int _id=sqlite3_column_int(statement, 0);

NSString *name=[[NSString alloc] initWithCString:(char *)sqlite3_column_text(statement, 1) encoding:NSUTF8StringEncoding];

NSLog(@"row>>id %i, name %@",_id,name);

}

sqlite3_finalize(statement);

}

sqlite3_close(database);

}

删除表操作

constchar *sql_drop_table="drop table if exists t";

constchar *sql_create_table="create table t(id int primary key,msg varchar(128))";

sqlite3_exec(db,sql_drop_table,0,0,&errmsg);

sqlite3_exec(db,sql_create_table,0,0,&errmsg);

插入数据

sqlite3_exec(db,"insert into t(id,msg) values(1,'Ady Liu')",NULL,NULL,&errmsg);

预编译操作

int i = 0;

sqlite3_stmt *stmt;

char ca[255];

//prepare statement

sqlite3_prepare_v2(db,"insert into t(id,msg) values(?,?)",-1,&stmt,0);

for(i=10;i<20;i++){

sprintf(ca,"HELLO#%i",i);

sqlite3_bind_int(stmt,1,i);

sqlite3_bind_text(stmt,2,ca,strlen(ca),NULL);

sqlite3_step(stmt);

sqlite3_reset(stmt);

}

sqlite3_finalize(stmt)

预编译操作比较麻烦的,完整的预编译操作的流程是:
通过sqlite3_prepare_v2()创建一个sqlite3_stmt对象
通过sqlite3_bind_*()绑定预编译字段的值
通过sqlite3_step()执行SQL语句
通过sqlite3_reset()重置预编译语句,重复操作2多次
通过sqlite3_finalize()销毁资源

预编译SQL语句中可以包含如下几种形式:
?
?NNN
:VVV
@VVV
$VVV
NNN代表数字,VVV代表字符串。

如果是?或者?NNN,那么可以直接sqlite3_bind_*()进行操作,如果是字符串,还需要通过sqlite3_bind_parameter_index()获取对应的index,然后再调用sqlite3_bind_*()操作。这通常用于构造不定条件的SQL语句(动态SQL语句)。

查询操作

写道

回调函数的解释参考最上面的描述。 首先声明一个回调函数。
int print_record(void *,int,char **,char **);

查询代码
//select data
ret = sqlite3_exec(db,"select * from t",print_record,NULL,&errmsg);
if(ret != SQLITE_OK){
fprintf(stderr,"query SQL error: %s\n",errmsg);
}

现在定义回调函数,只是简单的输出字段值。
int print_record(void *params,int n_column,char **column_value,char **column_name){
int i;
for(i=0;i<n_column;i++){
printf("\t%s",column_value[i]);
}
printf("\n");
return 0;
}

不使用回调的查询操作

写道

定义使用的变量
char **dbresult; int j,nrow,ncolumn,index;
查询操作
//select table
ret = sqlite3_get_table(db,"select * from t",&dbresult,&nrow,&ncolumn,&errmsg);
if(ret == SQLITE_OK){
printf("query %i records.\n",nrow);
index=ncolumn;
for(i=0;i<nrow;i++){
printf("[%2i]",i);
for(j=0;j<ncolumn;j++){
printf(" %s",dbresult[index]);
index++;
}
printf("\n");
}
}
sqlite3_free_table(dbresult);

受影响的记录数

我们可以使用sqlite3_change(sqlite3 *)的API来统计上一次操作受影响的记录数。
ret = sqlite3_exec(db,"delete from t",NULL,NULL,&errmsg);

if(ret == SQLITE_OK){

printf("delete records: %i\n",sqlite3_changes(db));

}

总结

写道

这里我们接触了SQLITE3的13个API:
sqlite3_open()
sqlite3_exec()
sqlite3_close()
sqlite3_prepare_v2
sqlite3_bind_*()
sqlite3_bind_parameter_index()
sqlite3_step()
sqlite3_reset()
sqlite3_finalize()
sqlite3_get_table
sqlite3_change()
sqlite3_free()
sqlite3_free_table()
事实上截止到SQLITE3.7.14(2012/09/03) 一共提供了204个API函数(http://www.sqlite.org/c3ref/funclist.html)。
但最精简的API函数大概有6个:
sqlite3_open()
sqlite3_prepare()
sqlite3_step()
sqlite3_column()
sqlite3_finalize()
sqlite3_close()
核心API也就10个(在精简API基础上增加4个):
sqlite3_exec()
sqlite3_get_table()
sqlite3_reset()
sqlite3_bind()
因此掌握起来还是比较容易的。

iOS 数据库持久化的更多相关文章

  1. iOS 数据持久化(扩展知识:模糊背景效果和密码保护功能)

    本篇随笔除了介绍 iOS 数据持久化知识之外,还贯穿了以下内容: (1)自定义 TableView,结合 block 从 ViewController 中分离出 View,轻 ViewControll ...

  2. iOS开发笔记-swift实现iOS数据持久化之归档NSKeyedArchiver

    IOS数据持久化的方式分为三种: 属性列表 (plist.NSUserDefaults) 归档 (NSKeyedArchiver) 数据库 (SQLite.Core Data.第三方类库等 归档(又名 ...

  3. [iOS]数据库第三方框架FMDB详细讲解

    [iOS]数据库第三方框架FMDB详细讲解 初识FMDB iOS中原生的SQLite API在进行数据存储的时候,需要使用C语言中的函数,操作比较麻烦.于是,就出现了一系列将SQLite API进行封 ...

  4. IOS数据持久化之归档NSKeyedArchiver

    IOS数据持久化的方式分为三种: 属性列表 (自定义的Property List .NSUserDefaults) 归档 (NSKeyedArchiver) 数据库 (SQLite.Core Data ...

  5. iOS数据库操作之coredata详细操作步骤

    CHENYILONG Blog iOS数据库操作之coredata详细操作步骤 技术博客http://www.cnblogs.com/ChenYilong/ 新浪微博http://weibo.com/ ...

  6. iOS数据持久化方式及class_copyIvarList与class_copyPropertyList的区别

    iOS数据持久化方式:plist文件(属性列表)preference(偏好设置)NSKeyedArchiver(归档)SQLite3CoreData沙盒:iOS程序默认情况下只能访问自己的程序目录,这 ...

  7. iOS 数据库操作(使用FMDB)

    iOS 数据库操作(使用FMDB)   iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.Plausibl ...

  8. android数据库持久化框架

    android数据库持久化框架

  9. IOS数据库操作SQLite3使用详解(转)

    iPhone中支持通过sqlite3来访问iPhone本地的数据库.具体使用方法如下1:添加开发包libsqlite3.0.dylib首先是设置项目文件,在项目中添加iPhone版的sqlite3的数 ...

随机推荐

  1. 两个正在运行的activity之间的通信

    在android应用程序开发的时候,从一个activity启动另一个activity并传递一些数据到新的activity非常的简单,但是当您需要让后台运行的activity回到前台并传递一些数据可能就 ...

  2. LSP“浏览器劫持概念

    关于Winsock LSP“浏览器劫持”,中招者一直高居不下,由于其特殊性,直接删除而不恢复LSP的正常状态很可能会导致无法上网所以对其修复需慎重.   先说说什么是Winsock LSP“浏览器劫持 ...

  3. java 个人总结

    每周课程总结链接: 第一周 第二周 第三周 第四周 第五周 第六周 第七周 第八周 第九周 第十周 java实验报告链接: 实验一 实验二 实验三 实验四 实验五 代码托管链接 课程收获: 学习任何语 ...

  4. Linux 之dhcp服务搭建

    DHCP(Dynamic Host Configuration Protocol,动态主机配置协议)是一个局域网的网络协议 dhcp服务器端监控端口67 涉及的配置文件:/etc/dhcp/dhcpd ...

  5. Python之路【第五篇】:面向对象及相关

    Python之路[第五篇]:面向对象及相关   面向对象基础 基础内容介绍详见一下两篇博文: 面向对象初级篇 面向对象进阶篇 其他相关 一.isinstance(obj, cls) 检查是否obj是否 ...

  6. 替换 PDF 文字

    1.从http://pan.baidu.com/s/1pJlVBqN下载Foxit Phantom.exe: 2.安装这个软件: ① 弹出这个对话框时选择“运行”: ② 授权协议选择“同意”: ③ 选 ...

  7. activiti搭建(五)BPMN介绍

    转载请注明源地址:http://www.cnblogs.com/lighten/p/5931207.html 对于BPMN我也不是十分清楚,目前也只是因为对于Modeler中不熟悉的组件查询,来对这部 ...

  8. POJ C程序设计进阶 编程题#3: 发票统计

    来源: POJ (Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩.) 注意: 总时间限制: 1000ms 内存限制: 65536kB 描述 有一个小型的报账系统,它有如 ...

  9. linux下最大文件数

    系统级:系统级设置对所有用户有效.可通过两种方式查看系统最大文件限制1 cat /proc/sys/fs/file-max 2 sysctl -a 查看结果中fs.file-max这项的配置数量如果需 ...

  10. DataTable.Select

    转载请注明出处:http://www.cnblogs.com/havedream/p/4453297.html 方法:DataTable.Select 作用:获取 DataRow 对象的数组. 重载: ...