一、常用方法

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(如有雷同,纯属巧合)的更多相关文章

  1. 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 ...

  2. 练习一:SQLite基本操作

    一.基础知识: 运用场景: 1>应用运行需要保存一系列有一定关系有一定结构的数据(文本也可以但是存储效率低) 2>文件类型:.db(一个数据库就是一个.db文件) 3>路径:/dat ...

  3. Android 的 Sqlite基本操作

    在 SQL 数据库中保存数据 使用数据库 将数据保存到数据库对于重复或结构化数据(比如契约信息)而言是理想之选. 本课程假定您基本熟悉 SQL 数据库并且可帮助您开始在 Android 中使用 SQL ...

  4. sqlite基本操作

    sqlite准备步骤; .下载:https://www.sqlite.org/download.html: sqlite-dll-win64-3250200.zip 和 sqlite-tools-wi ...

  5. 【转】C# 对sqlite基本操作,带批量插入

    原文地址:https://download.csdn.net/download/mic_gary/10154869 public class SQLiteHelper { //数据库连接字符串 pub ...

  6. 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 ...

  7. iOS开发之Masonry框架源码深度解析

    Masonry是iOS在控件布局中经常使用的一个轻量级框架,Masonry让NSLayoutConstraint使用起来更为简洁.Masonry简化了NSLayoutConstraint的使用方式,让 ...

  8. iOS开发之Masonry框架源码解析

    Masonry是iOS在控件布局中经常使用的一个轻量级框架,Masonry让NSLayoutConstraint使用起来更为简洁.Masonry简化了NSLayoutConstraint的使用方式,让 ...

  9. IOS OC 计算器算法(不考虑优先级)

    个人见解:为还在计算器算法方面迷惑的同学一个数据处理解决方案:定义一个可变数组array,一个可变字符串str,使字符通过[array addObject:str];方法添加到可变数组,每当触发运算符 ...

随机推荐

  1. 谈谈对JVM的理解

            JVM可谓是学习JAVA基础中的基础了,但仍有不少同学对JVM概念还是比较模糊,甚至没有听说过,对java的理解也只是在基础语法 层面,本文就将对JVM进行初步介绍,因篇幅所限,只能介 ...

  2. 详解C#的协变和逆变

    一.使用协变(Covariance)和逆变(Contravariance )能够实现数组之间.委托实例和方法之间.泛型委托实例之间.泛型接口的变量和泛型类型的对象之间.泛型接口的变量之间的隐式转换:使 ...

  3. A brief introduction to per-cpu variables

    墙外通道:http://thinkiii.blogspot.com/2014/05/a-brief-introduction-to-per-cpu.html per-cpu variables are ...

  4. 120分钟React快速扫盲教程

    在教程开端先说些题外话,我喜欢在学习一门新技术或读过一本书后,写一篇教程或总结,既能帮助消化,也能加深印象和发现自己未注意的细节,写的过程其实仍然是一个学习的过程.有个记录的话,在未来需要用到相关知识 ...

  5. 一张图读懂PBN旁切转弯计算

    当DOC8168进入PBN章节以后,所有的保护区不再标注风螺旋的字母位置点.似乎ICAO已经有了精确计算的方法,只是没有告诉我们.沿着风螺旋的轨迹一路走来,切线与角度的换算方法想必已经相当熟悉了吧,这 ...

  6. R语言实战(三)——模拟随机游走数据

    一.模拟随机游走数据示例 x <- matrix(0,1000,1) for(i in 1:1000){ x[i+1] <- x[i]+rnorm(1) } plot(x,type=&qu ...

  7. soapUI工具使用方法、简介、接口测试

    一.soapUI简介 SOAP: WebService通过Http协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明HTTP消息头的内容格 ...

  8. js .map方法

    map这里的map不是“地图”的意思,而是指“映射”.[].map(); 基本用法跟forEach方法类似: array.map(callback,[ thisObject]); callback的参 ...

  9. 初学HTML-6

    表单:专门用来收集用户信息 表单元素:在HTML中,标签/标记/元素都是指HTML中的标签. eg:<a>a标签/a标记/a元素 浏览器中所以得表单标签都有特殊的外观和默认的功能. 格式: ...

  10. postgresql-10.1-3-windows-x64 安装之后,起动pgAdmin 4问题(win10)

    运行pgAdmin出现”pgAdmin 4  the application server could not be contant“ 窗口. 参考:https://stackoverflow.com ...