sqlite学习
一鼓作气,今天继续学习了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学习的更多相关文章
- SQLite学习笔记(七)&&事务处理
说到事务一定会提到ACID,所谓事务的原子性,一致性,隔离性和持久性.对于一个数据库而言,通常通过并发控制和故障恢复手段来保证事务在正常和异常情况下的ACID特性.sqlite也不例外,虽然简单,依然 ...
- Sqlite学习笔记(四)&&SQLite-WAL原理
Sqlite学习笔记(三)&&WAL性能测试中列出了几种典型场景下WAL的性能数据,了解到WAL确实有性能优势,这篇文章将会详细分析WAL的原理,做到知其然,更要知其所以然. WAL是 ...
- SQLite学习手册(目录)
链接地址:http://www.cnblogs.com/stephen-liu74/archive/2012/01/22/2328757.html 在实际的应用中,SQLite作为目前最为流行的开源嵌 ...
- Sqlite学习笔记(四)&&SQLite-WAL原理(转)
Sqlite学习笔记(三)&&WAL性能测试中列出了几种典型场景下WAL的性能数据,了解到WAL确实有性能优势,这篇文章将会详细分析WAL的原理,做到知其然,更要知其所以然. WAL是 ...
- SQLite学习手册
在实际的应用中,SQLite作为目前最为流行的开源嵌入式关系型数据库,在系统的架构设计中正在扮演着越来越为重要的角色.和很多其它嵌入式NoSQL数据库不同的是,SQLite支持很多关系型数据库的基本特 ...
- SQLite 学习笔记
SQLite 学习笔记. 一.SQLite 安装 访问http://www.sqlite.org/download.html下载对应的文件. 1.在 Windows 上安装 SQLite. ...
- SQLite学习手册(转)
原文网址:http://www.cnblogs.com/stephen-liu74/archive/2012/01/22/2328757.html 在实际的应用中,SQLite作为目前最为流行的开源嵌 ...
- sqlite学习笔记7:C语言中使用sqlite之打开数据库
数据库的基本内容前面都已经说得差点儿相同了.接下看看如何在C语言中使用sqlite. 一 接口 sqlite3_open(const char *filename, sqlite3 **ppDb) 打 ...
- SQlite 学习资料
很有用的开源跨平台数据库,可以作为客户端的小型内存数据库使用,据说它有N多用户(Nokia's Symbian,Mozilla,Abobe,Google,阿里旺旺,飞信,Chrome,FireFo ...
随机推荐
- [教程] [承風雅傳HSU]用ES4封裝Win7---ES4 Win7封裝教程(未完待續)
[教程] [承風雅傳HSU]用ES4封裝Win7---ES4 Win7封裝教程(未完待續) a10036it 发表于 2015-7-27 21:11:19 https://www.itsk.com/t ...
- nginx配合zabbix编译安装时web下一步跳转问题
很多时候编译安装的时候把zabbix的php包拷贝到web所在目录之后(本文为nginx所在html目录),网页打开http:/localhost/zabbix却进不去下图: 或者是点了下一步没反应, ...
- 记录centos6.8安装Oracle10.2.0.1过程中的错误解决
[root@hadoop01 database]# ./runInstaller ./runInstaller: /opt/database/install/.oui: /lib/ld-linux.s ...
- python3 不同目录间模块调用
#Author by Andy #_*_ coding:utf-8 _*_ #__file__获取当前程序的相对路径 import os,sys #print(__file__) # os.path. ...
- AJAX第二发
开始总结自己在项目上的使用AJAX的情况: 该图为向后台请求的数据,前台返回的结果,返回的数据类型为object,businessObj由许多key组成,我们项目前台需要调用的数据就藏在数组recor ...
- Java开发常用的在线工具
原文出处: hollischuang(@Hollis_Chuang) 作为一个Java开发人员,经常要和各种各样的工具打交道,除了我们常用的IDE工具以外,其实还有很多工具是我们在日常开发及学习过程中 ...
- javascript 提取表单元素生成用于提交的对象(序列化 html 表单)
function serialize(f) { var o = {}; var s = f.getElementsByTagName("select"); for (var i = ...
- table表格中的内容溢出布局方式
什么是内容溢出呢?其实就是当文字很多的时候,如果内容区域只有那么长,那么多出的部分以点点点代替. 这次做的案例是在table里面,我们知道当我们在table里输入过多的文字内容的时候会撑乱表格,例如一 ...
- uva 10817(状压dp)
题意:就是有个学校要招老师.要让没门课至少有两个老师可以上.每个样样例先输入三个数字课程数量s,已经在任的老师数量,和应聘的老师数量.已经在任的一定要聘请. 思路是参考了刘汝佳书上的,关键如何状压. ...
- JVM 平台上的各种语言的开发指南
JVM 平台上的各种语言的开发指南 为什么我们需要如此多的JVM语言? 在2013年你可以有50中JVM语言的选择来用于你的下一个项目.尽管你可以说出一大打的名字,你会准备为你的下一个项目选择一种新的 ...