一鼓作气,今天继续学习了sqlite数据库在Xcode上的一些操作,主要是通过用oc代码进行salite表格的创建,删除,修改;以及对现有的表格数据进行增,删,改,查。虽然有点累,但是收获不小,感觉很充实,继续加油!

//把数据库sqlite3导入到工程(在Bulider Phrase 中的Linker中点击➕号,查找sqlite3文件,选择再添加即可)

//打开数据库

//提供C的字符串,c串时我们要打开数据库的完整路径和文件名

NSString *path=NSHomeDirectory();//获得家的路径

path=[path stringByAppendingPathComponent:@"mydb.sqlite"];

NSLog(@"%@",path);

sqlite3 *db;

//打开数据库,如果没有这个数据库,就创建这个数据库的文件并且打开这个数据库,如果有这个数据库就直接打开该数据库

sqlite3_open([path UTF8String], &db);

int result=sqlite3_open([path UTF8String], &db);

//判断打开数据库是否成功

if (result!=SQLITE_OK) {

NSLog(@"打开失败!");

}

//关闭数据库

sqlite3_close(db);

//提供C的字符串,c串时我们要打开数据库的完整路径和文件名

NSString *path1=NSHomeDirectory();//获得家的路径

path1=[path1 stringByAppendingPathComponent:@"mydb.sqlite"];

sqlite3 *mydb;//创建一个数据库名叫mydb

//打开数据库,如果没有这个数据库,就创建这个数据库的文件并且打开这个数据库,如果有这个数据库就直接打开该数据库

sqlite3_open([path UTF8String], &mydb);

//对数据库进行操作

//定制一个sql表

char *sql="create table if not exists t_student(name text,age integer)";

char *err;//出错信息

//运行sql,并返回运行结果

result=sqlite3_exec(mydb, sql, NULL, NULL, &err);

//判断运行是否成功

if (result!=SQLITE_OK) {

NSLog(@"运行sql错误,error原因:%s",err);

}

/*

//增

NSString *name=self.nameText.text;

NSString *age=self.ageText.text;

//sql="insert into t_student(name,age) values('张三',22) ";

NSString *sql1=[NSString stringWithFormat:@"insert into t_student(name,age) values('%@',%@)",name,age];

//将OC的字符串转化为C字符串

//[sql1 UTF8String];

//运行sql,并返回运行结果

result=sqlite3_exec(mydb,[sql1 UTF8String],NULL,NULL,&err);

if (result!=SQLITE_OK)

{

NSLog(@"运行sql错误,error原因:%s",err);

}

*/

/*

//增,(可以插入特殊字符,用绑定的方式)

NSString *name=self.nameText.text;

NSString *age=self.ageText.text;

char *sql2="insert into t_student(name,age) values(?,?) ";

sqlite3_stmt *stmt;//stmt本身为指向行的指针,故该定义为一个指向指针的指针,即表示一个二维数组

//运行sql,并返回运行结果

result=sqlite3_prepare_v2(mydb,sql2,-1,&stmt,NULL);

if (result==SQLITE_OK)

{

// 绑定参数

result=sqlite3_bind_text(stmt, 1, [name UTF8String],-1, NULL);

//判断绑定姓名是否成功

if (result!=SQLITE_OK) {

NSLog(@"绑定姓名失败!!!");

}

// 绑定参数

result=sqlite3_bind_int(stmt, 2, [age intValue]);

//判断绑定姓名是否成功

if (result!=SQLITE_OK) {

NSLog(@"绑定年龄失败!!!");

}

}

if (sqlite3_step(stmt)!=SQLITE_DONE)

{

NSLog(@"插入数据失败!!!");

}

sqlite3_finalize(stmt);

*/

/*

//删

sql="delete from t_student where age=26";

//运行sql,并返回运行结果

result=sqlite3_exec(mydb, sql, NULL, NULL, &err);

//判断运行是否成功

if (result!=SQLITE_OK) {

NSLog(@"运行sql错误,error原因:%s",err);

}

*/

/*

//删除,用绑定的方式

NSString *name=self.nameText.text;

//NSString *age=self.ageText.text;

sqlite3_stmt *stmt;

char * sql3="delete from t_student where name=?";

//运行sql,并返回运行结果

result=sqlite3_prepare_v2(mydb, sql3, -1, &stmt, NULL);

//判断运行是否成功

if (result==SQLITE_OK)

{

// 绑定参数

result=sqlite3_bind_text(stmt, 1, [name UTF8String],-1, NULL);

//判断绑定姓名是否成功

if (result!=SQLITE_OK) {

NSLog(@"绑定姓名失败!!!");

}

else

{

// 绑定参数

result=sqlite3_step(stmt);

//判断绑定姓名是否成功

if(result!=SQLITE_DONE)

{

NSLog(@"删除失败!!!");

}

}

}

else

{

NSLog(@"绑定失败!!!");

}

sqlite3_finalize(stmt);

*/

/*

//改

sql="update t_student set name='赵六' where age=22 ";

//运行sql,并返回运行结果

result=sqlite3_exec(mydb, sql, NULL, NULL, &err);

//判断运行是否成功

if (result!=SQLITE_OK)

{

NSLog(@"运行sql错误,error原因:%s",err);

}

*/

//修改,用绑定的方式

char *sql4="update t_student set name=? where age=?";

NSString *name=self.nameText.text;

NSString *age=self.ageText.text;

BOOL bFlag=NO;

sqlite3_stmt *stmt;

result=sqlite3_prepare_v2(mydb, sql4 , -1, &stmt ,NULL);

if (result==SQLITE_OK) {

result=sqlite3_bind_text(stmt, 1, [name UTF8String], -1, NULL);

if (result!=SQLITE_OK) {

NSLog(@"绑定姓名失败!!!");

bFlag=YES;

}

result=sqlite3_bind_int(stmt, 2, [age intValue]);

if (result!=SQLITE_OK) {

NSLog(@"绑定年龄失败!!!");

bFlag=YES;

}

if (bFlag==NO) {

result=sqlite3_step(stmt);

if (result!=SQLITE_DONE) {

NSLog(@"修改失败!!!");

}

}

}

else

{

NSLog(@"预处理失败(准备运行失败 )!!!");

}

//查

sql="select * from t_student";

result=sqlite3_prepare_v2(mydb, sql , -1, &stmt ,NULL);

if (result==SQLITE_OK)

{

//遍历返回的结构

while(sqlite3_step(stmt)==SQLITE_ROW)//的到返回结构的一行

{

char*name=(char*)sqlite3_column_text(stmt, 0);//的到返回结构的一列,其中0代表第一列,依次类推

int age=sqlite3_column_int(stmt, 1);//的到返回结果的第二列

NSString *strname=[NSString stringWithUTF8String:name];

NSLog(@"name=%@,age=%d",strname,age);

}

}

else

{

NSLog(@"预处理失败");

}

sqlite3_finalize(stmt);//释放层数占用的资源

sqlite3_close(mydb);

sqlite学习的更多相关文章

  1. SQLite学习笔记(七)&&事务处理

    说到事务一定会提到ACID,所谓事务的原子性,一致性,隔离性和持久性.对于一个数据库而言,通常通过并发控制和故障恢复手段来保证事务在正常和异常情况下的ACID特性.sqlite也不例外,虽然简单,依然 ...

  2. Sqlite学习笔记(四)&&SQLite-WAL原理

    Sqlite学习笔记(三)&&WAL性能测试中列出了几种典型场景下WAL的性能数据,了解到WAL确实有性能优势,这篇文章将会详细分析WAL的原理,做到知其然,更要知其所以然. WAL是 ...

  3. SQLite学习手册(目录)

    链接地址:http://www.cnblogs.com/stephen-liu74/archive/2012/01/22/2328757.html 在实际的应用中,SQLite作为目前最为流行的开源嵌 ...

  4. Sqlite学习笔记(四)&&SQLite-WAL原理(转)

    Sqlite学习笔记(三)&&WAL性能测试中列出了几种典型场景下WAL的性能数据,了解到WAL确实有性能优势,这篇文章将会详细分析WAL的原理,做到知其然,更要知其所以然. WAL是 ...

  5. SQLite学习手册

    在实际的应用中,SQLite作为目前最为流行的开源嵌入式关系型数据库,在系统的架构设计中正在扮演着越来越为重要的角色.和很多其它嵌入式NoSQL数据库不同的是,SQLite支持很多关系型数据库的基本特 ...

  6. SQLite 学习笔记

    SQLite 学习笔记. 一.SQLite 安装    访问http://www.sqlite.org/download.html下载对应的文件.    1.在 Windows 上安装 SQLite. ...

  7. SQLite学习手册(转)

    原文网址:http://www.cnblogs.com/stephen-liu74/archive/2012/01/22/2328757.html 在实际的应用中,SQLite作为目前最为流行的开源嵌 ...

  8. sqlite学习笔记7:C语言中使用sqlite之打开数据库

    数据库的基本内容前面都已经说得差点儿相同了.接下看看如何在C语言中使用sqlite. 一 接口 sqlite3_open(const char *filename, sqlite3 **ppDb) 打 ...

  9. SQlite 学习资料

      很有用的开源跨平台数据库,可以作为客户端的小型内存数据库使用,据说它有N多用户(Nokia's Symbian,Mozilla,Abobe,Google,阿里旺旺,飞信,Chrome,FireFo ...

随机推荐

  1. mysql delete 使用别名 语法

    今天删除数据,写了这么条sql语句, DELETE   from  sys_menus s WHERE s.MENU_ID in (86,87,88); 结果报错.. [Err] 1064 - You ...

  2. SSIS excel2003文件导入列名显示为F1,F2 - FN

    问题现象: 数据源2003版本的EXCEL文件,第一列是空白,数据是从第二列开始的.所以SSIS中用EXCEL数据源倒入这个EXCEL时,所有的列显示不出来,显示的是F1,F2  - FN. 解决方法 ...

  3. 解析json串,利用正则表达式,split

    public class SplitJson { public static void main(String[] args) {        // TODO Auto-generated meth ...

  4. ThinkPHP3.2.3使用cli命令行模式

    使用tp3.2.3的cli模式时,报错.加上绝对路径还是报错.所以采用普通模式 if(version_compare(PHP_VERSION,'5.3.0','<')) die('require ...

  5. 关于启用 HTTPS 的一些经验分享(一)

    转载: 关于启用 HTTPS 的一些经验分享(一) 随着国内网络环境的持续恶化,各种篡改和劫持层出不穷,越来越多的网站选择了全站 HTTPS.就在今天,免费提供证书服务的 Let's Encrypt ...

  6. css 分享之background-attachment 属性

    微分享才发现的css背景图达到的效果代码属性: background-attachment -- 定义背景图片随滚动轴的移动方式: 值 描述 scroll 默认值.背景图像会随着页面其余部分的滚动而移 ...

  7. chrome 扩展包 postman 的安装

    由于chrome网上应用不能使用.添加扩展程序,需要其他的办法. 1.下载postman安装包.下载地址 2.这一步按照这个下载包中的方法,也可以,可以忽略其错误. 先解压出crx,使用两个办法,使用 ...

  8. 常看常遇见之一——BS架构VS CS架构

    常看常遇见之一——BS架构VS CS架构 1.BS架构 即Browser/Server(浏览器/服务器)结构,是随着Internet技术的兴起,对C/S结构的一种变化或者改进的结构.在这种结构下,用户 ...

  9. 深入Docker

    深入Docker 作者:ramanallamilli 随着持续交付等新型开发方法的兴起,工程师再也不会凡事靠运气,希望提交代码上去后,它能在未知环境正常运行.我们可以看到业界这样的转变——开发,质量保 ...

  10. C——malloc & free(转载自bccn C语言论坛)

    原帖及讨论:http://bbs.bccn.net/thread-82212-1-1.html 原文链接:http://www.bccn.net/Article/kfyy/cyy/jszl/20060 ...