SQLite基本操作-----IOS(如有雷同,纯属巧合)
一、常用方法
sqlite3 *db, 数据库句柄,跟文件句柄FILE很类似
sqlite3_stmt *stmt, 这个相当于ODBC的Command对象,用于保存编译好的SQL语句
sqlite3_open(), 打开数据库,没有数据库时创建。
sqlite3_exec(), 执行非查询的sql语句
Sqlite3_step(), 在调用sqlite3_prepare后,使用这个函数在记录集中移动。
Sqlite3_close(), 关闭数据库文件
还有一系列的函数,用于从记录集字段中获取数据,如
sqlite3_column_text(), 取text类型的数据。
sqlite3_column_blob(),取blob类型的数据
sqlite3_column_int(), 取int类型的数据
二、创建表
创建表的时候需要预处理和执行创建两个过程
执行创建的时多选择sqlite3_step
三、相关代码
1、打开或者创建数据库
sqlite3 *sqlDataBase;
-(BOOL)createOrOpen:(NSString *)dbName
{
//获取用户域覆径信息
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentationDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:];
/**
*Users/admin/Library/Application Support/iPhone Simulator/7.1/Applications/8E23557E-AAA6-471A-AAFE-E036BF1B7E4C/Library/Documentation
*判断用户域是否有数据库dbNmae
*/
NSString *path = [documentsDirectory stringByAppendingPathComponent:dbName];
NSFileManager *fileManageer = [NSFileManager defaultManager];
//如果用户域内有该数据库,则返回yes,否则返回NO
BOOL find = [fileManageer fileExistsAtPath:path];
if(find) //对找到进行处理,如果找到了,并且打开了,则返回yes
{
//打开该数据库,如果打开失败,则返回NO,否则返回yes
if(sqlite3_open([path UTF8String], &sqlDataBase)!= SQLITE_OK)
{
//关闭sqlDataBase,实际是释放了它
sqlite3_close(sqlDataBase);
return NO;
}
return YES;
}
NSLog(@"%d",sqlite3_open([path UTF8String], &sqlDataBase));
//创建数据库,创建返回yes,并且打开数据库,否则返回NO
if(sqlite3_open([path UTF8String], &sqlDataBase)==SQLITE_OK)
{
return YES;
}else
{
//关闭sqlDataBase,实际是释放了它
sqlite3_close(sqlDataBase);
return NO;
}
return NO;
}
2、插入数据
//向表中插入数据
-(void)insertMBkey:(NSString *)key
{
BOOL isOK = NO;
sqlite3_stmt *statement;
static char *sql = "INSERT INTO user VALUES ('1', 'Bill', '河南', 'ssss','2')";
int success = sqlite3_prepare_v2(sqlDataBase, sql, -, &statement, NULL);
if(success !=SQLITE_OK)
{
isOK = NO;
}else
{
sqlite3_bind_text(statement, , [key UTF8String], -, SQLITE_TRANSIENT);
success = sqlite3_step(statement);
sqlite3_finalize(statement);
}
if(success ==SQLITE_ERROR)
{
isOK = NO;
}else
{
isOK=YES;
}
return;
}
3、查询数据
//查询数据
-(void)GetList:(NSMutableArray *)KeysList
{
BOOL isOK = NO;
sqlite3_stmt *statement;
static char *sql = "select id,address from user";
int success = sqlite3_prepare_v2(sqlDataBase, sql, -, &statement, NULL);
if(success !=SQLITE_OK)
{
isOK = NO;
}else
{
//查询结果集中一条一条地遍历所有记录,这里的数字对应的时列值
while (sqlite3_step(statement)==SQLITE_ROW) {
int kid = sqlite3_column_int(statement, );
char *key = (char *)sqlite3_column_text(statement, );
UserInfo *userModel = [[UserInfo alloc] init];
userModel.userId =kid;
if (key) {
userModel.userAddress = [NSString stringWithUTF8String:key];
}
[KeysList addObject:userModel];
sqlite3_finalize(statement);
}
NSLog(@"%@",KeysList);
if(success==SQLITE_ERROR)
{
isOK = NO;
}else
{
isOK = YES;
}
return;
}
}
SQLite基本操作-----IOS(如有雷同,纯属巧合)的更多相关文章
- XCode 4.3 Unable to load persistent store UserDictionary.sqlite 以及 ios simulator failed to install the application
I have been working on an iOS app for some time, all of a sudden I am getting the following crash ev ...
- 练习一:SQLite基本操作
一.基础知识: 运用场景: 1>应用运行需要保存一系列有一定关系有一定结构的数据(文本也可以但是存储效率低) 2>文件类型:.db(一个数据库就是一个.db文件) 3>路径:/dat ...
- Android 的 Sqlite基本操作
在 SQL 数据库中保存数据 使用数据库 将数据保存到数据库对于重复或结构化数据(比如契约信息)而言是理想之选. 本课程假定您基本熟悉 SQL 数据库并且可帮助您开始在 Android 中使用 SQL ...
- sqlite基本操作
sqlite准备步骤; .下载:https://www.sqlite.org/download.html: sqlite-dll-win64-3250200.zip 和 sqlite-tools-wi ...
- 【转】C# 对sqlite基本操作,带批量插入
原文地址:https://download.csdn.net/download/mic_gary/10154869 public class SQLiteHelper { //数据库连接字符串 pub ...
- Android的SQLite基本操作
涉及SQLite的增删改查,结果用log显示 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 ...
- iOS开发之Masonry框架源码深度解析
Masonry是iOS在控件布局中经常使用的一个轻量级框架,Masonry让NSLayoutConstraint使用起来更为简洁.Masonry简化了NSLayoutConstraint的使用方式,让 ...
- iOS开发之Masonry框架源码解析
Masonry是iOS在控件布局中经常使用的一个轻量级框架,Masonry让NSLayoutConstraint使用起来更为简洁.Masonry简化了NSLayoutConstraint的使用方式,让 ...
- IOS OC 计算器算法(不考虑优先级)
个人见解:为还在计算器算法方面迷惑的同学一个数据处理解决方案:定义一个可变数组array,一个可变字符串str,使字符通过[array addObject:str];方法添加到可变数组,每当触发运算符 ...
随机推荐
- 大牛是怎么思考设计MySQL优化方案
在进行MySQL的优化之前,必须要了解的就是MySQL的查询过程,很多查询优化工作实际上就是遵循一些原则,让MySQL的优化器能够按照预想的合理方式运行而已. 1.优化的哲学 注:优化有风险,涉足需谨 ...
- Spring Boot + Spring Cloud 实现权限管理系统 后端篇(二十):服务熔断(Hystrix、Turbine)
在线演示 演示地址:http://139.196.87.48:9002/kitty 用户名:admin 密码:admin 雪崩效应 在微服务架构中,由于服务众多,通常会涉及多个服务层级的调用,而一旦基 ...
- java 面试基础总结(二)---多线程
1.实现多线程的三种方法 1.继成Thread 类,覆盖run()方法即可 2.implements Runnable接口 3.implements Callale接口,执行时通过FutureTask ...
- CynosDB技术详解——存储集群管理
本文由腾讯云数据库发表 前言 CynosDB是架构在CynosFS之上的分布式关系数据库系统,为最大化利用存储资源,平衡资源之间的竞争,检查资源使用情况,需要一套高效稳定的分布式集群管理系统(SCM: ...
- 如何设计和实现高可用的MySQL
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯云数据库 TencentDB发表于云+社区专栏 王甲坤,腾讯高级工程师.腾讯云关系型数据库MySQL负责人,拥有多年客户端.数据库 ...
- Java 8 新特性-菜鸟教程 (8) -Java 8 日期时间 API
Java 8 日期时间 API Java 8通过发布新的Date-Time API (JSR 310)来进一步加强对日期与时间的处理. 在旧版的 Java 中,日期时间 API 存在诸多问题,其中有: ...
- 微信小程序bug记录与解决
微信小程序bug记录 textarea textarea在模拟器上没有padding,可是在真机上会自带padding,而且在外部改不了,并且在安卓和IOS上padding还不一样 第一张图是在开发工 ...
- [NOI 2017]蚯蚓排队
Description 题库链接 蚯蚓幼儿园有 \(n\) 只蚯蚓.幼儿园园长神刀手为了管理方便,时常让这些蚯蚓们列队表演. 所有蚯蚓用从 \(1\) 到 \(n\) 的连续正整数编号.每只蚯蚓的长度 ...
- 正则表达式,re模块
一,正则表达式 正则表达式是对字符串操作的一种逻辑公式,我们一般使用正则表达式对字符串进行匹配和过滤,使用正则的优缺点,我们可以去http://tool.chinaz.com/regex/进行测试. ...
- struts2、hibernate以及spring是如何配置的
第一次使用这3大框架进行网站编写的人没有一个清楚的流程,建起网站来会比较头疼,今天来讲讲3大框架的配置 基本流程: 用户点击页面之后,服务器收到一个请求,请求经过web.xml的拦截器过滤后进入act ...