iOS中sqlite的详细用法

 更新时间:2016年05月05日 09:42:35   作者:甘超波  
在iOS中,也同样支持sqlite。目前有很多第三方库,封装了sqlite操作,比如swift语言写的SQLite.swift,对sqlite感兴趣的小伙伴们可以参考一下

本文实例为大家分享了ios中sqlite的具体操作方法,供大家参考,具体内容如下

#import <sqlite3.h>

@interface ViewController ()
{
 sqlite3 *_sqldb;
}

@end

@implementation ViewController

- (void)viewDidLoad
{
 [super viewDidLoad];
 // Do any additional setup after loading the view, typically from a nib.
 [self OpenDb];
 [self createTable];
 [self insertData];
 [self FindData];
}


//打开数据库

-(void)OpenDb{
 
 NSArray *arrs= NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
 //创建数据库,如果数据库存在就直接打开,不存在就创建打开
 NSString *path=[arrs lastObject] ;
 NSString *documentpath= [path stringByAppendingPathComponent:@"sql.db"];
 int reslut= sqlite3_open([documentpath UTF8String], &_sqldb);
 if(reslut==SQLITE_OK){
 NSLog(@"数据库已被打开");
 }
 
}
//通过数据库实例创建表
-(void)createTable{
 //不带参数的sql语句
 const char* sql="create table if not exists t_person (id integer primary key autoincrement,name text,age integer);";
 char *error;
 //sqlite3_exec可以执行一切不带参数的SQL语句。如果是带参数最好不用,防止SQL注入漏洞攻击
 int resutl= sqlite3_exec(_sqldb, sql, NULL, NULL, &error);
 if(resutl==SQLITE_OK){
 NSLog(@"创建表成功");
 }
else{
 NSLog(@"创建表失败--》%s",error);
}
}

//插入数据
-(void)insertData{
 //带参数的SQL语句 "?"是带参数的占位符
 const char * sql="insert into t_person(name,age) values(?,?);";
 sqlite3_stmt *stmp;
 //在执行SQL语句之前检查SQL语句语法,-1代表字符串的长度
 int result= sqlite3_prepare_v2(_sqldb, sql, -1, &stmp, NULL);
 if(result==SQLITE_OK){
 NSLog(@"插入SQL语句语法没有问题");
 //绑定参数,插入的参数的下标是从1开始
 sqlite3_bind_text(stmp, 1, "gcb", -1, NULL);
 sqlite3_bind_int(stmp, 2, 12);
 
 //执行参参数的SQL语句,不能有exec
 int result=sqlite3_step(stmp);
 //插入进行判断,要用sqLite_Done来判断
 if(result==SQLITE_DONE){
  NSLog(@"插入成功");
 }
 else{
  NSLog(@"插入失败") ;
 }
 
 }
 else{
 NSLog(@"插入SQL语句有问题");
 }
}

-(void)FindData{
 char *sql="select id,name,age from t_person";
 //查询做好用step执行
 sqlite3_stmt *stmt;
 //检查SQL语句的语法问题
 int result= sqlite3_prepare_v2(_sqldb, sql, -1, &stmt, NULL);
 if(result==SQLITE_OK){
 while (sqlite3_step(stmt)==SQLITE_ROW) {
  //查询的列是0开始 插入的列从1开始
//  int xh=sqlite3_column_int(stmt, 0);
  int xh=sqlite3_column_int(stmt, 0);
  char * name=(char *)sqlite3_column_text(stmt, 1);
  int age=sqlite3_column_int(stmt, 2);
  NSLog(@"xh=%i-->name=%s-->age=%i",xh,name,age);
  
  
  
 }
 }
 else{
 NSLog(@"查询SQL语法有误");
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助。

相关文章

  • IOS利用CocoaHttpServer搭建手机本地服务器

    IOS利用CocoaHttpServer搭建手机本地服务器

    这篇文章主要介绍了IOS利用CocoaHttpServer搭建手机本地服务器的步骤,帮助大家更好的理解和学习使用ios开发,感兴趣的朋友可以了解下
    2021-04-04
  • 使用Swift代码实现iOS手势解锁、指纹解锁实例详解

    使用Swift代码实现iOS手势解锁、指纹解锁实例详解

    这篇文章主要介绍了使用Swift代码实现iOS手势解锁、指纹解锁的实现过程,非常不错具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-06-06
  • iOS体验性优化之RTL适配右滑返回的实现

    iOS体验性优化之RTL适配右滑返回的实现

    这篇文章主要给大家介绍了关于iOS体验性优化之RTL适配右滑返回实现的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-01-01
  • iOS之基于FreeStreamer的简单音乐播放器示例

    iOS之基于FreeStreamer的简单音乐播放器示例

    这篇文章主要介绍了iOS之基于FreeStreamer的简单音乐播放器示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • IOS LaunchScreen设置启动图片与启动页停留时间详解

    IOS LaunchScreen设置启动图片与启动页停留时间详解

    这篇文章主要介绍了IOS LaunchScreen设置启动图片与启动页停留时间详解的相关资料,需要的朋友可以参考下
    2017-02-02
  • IOS中多手势之间的冲突和解决办法

    IOS中多手势之间的冲突和解决办法

    这篇文章主要介绍了IOS中多手势之间的冲突和解决办法的相关资料,需要的朋友可以参考下
    2017-07-07
  • 阿里数据iOS端启动速度优化心得

    阿里数据iOS端启动速度优化心得

    本篇文章给大家详细分析了阿里数据iOS端启动速度优化的知识点以及心得,对此有兴趣的朋友参考学习下吧。
    2018-02-02
  • IOS客户端接入微信支付

    IOS客户端接入微信支付

    对于一个ios的app,如果有一些虚拟的商品或者服务需要通过在线支付来收费的话,一般有几种主流的选择。如果是通过APP调用支付平台APP的思路的话,一个是调起支付宝客户端,一个则是调起微信支付。本文给大家分享ios客户端接入微信支付,需要的朋友可以参考下
    2015-09-09
  • iOS中的实时远程配置全纪录

    iOS中的实时远程配置全纪录

    这篇文章主要给大家介绍了关于iOS中实时远程配置的相关资料,文中通过示例代码介绍的非常详细,对各位iOS开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-01-01
  • 如何在自己的电脑上配置APNS推送环境

    如何在自己的电脑上配置APNS推送环境

    这篇文章主要介绍了如何在自己的电脑上配置APNS推送环境的相关资料,需要的朋友可以参考下
    2015-11-11

最新评论