zoukankan      html  css  js  c++  java
  • SQLite3数据库

    SQLite3数据库

    一、创建、打开、关闭数据库

    1、创建或打开数据库

    // path是数据库文件的存放路径

    sqlite3 *db = NULL;

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

     

    代码解析:

    sqlite3_open()将根据文件路径打开数据库,如果不存在,则会创建一个新的数据库。如果result等于常量SQLITE_OK,则表示成功打开数据库

    sqlite3 *db:一个打开的数据库实例

    数据库文件的路径必须以C字符串(而非NSString)传入

     

    2、关闭数据库:sqlite3_close(db);

     

    二、执行不返回数据的SQL语句

    1、执行创表语句

    char *errorMsg = NULL;  // 用来存储错误信息

    char *sql = "create table if not exists t_person(id integer primary key autoincrement, name text, age integer);";

    int result = sqlite3_exec(db, sql, NULL, NULL, &errorMsg);

    代码解析:

    sqlite3_exec()可以执行任何SQL语句,比如创表、更新、插入和删除操作。但是一般不用它执行查询语句,因为它不会返回查询到的数据

    sqlite3_exec()还可以执行的语句:

    ①  开启事务:begin transaction;

    ②  回滚事务:rollback;

    ③  提交事务:commit;

     

    二、带占位符插入数据

    char *sql = "insert into t_person(name, age) values(?, ?);";

    sqlite3_stmt *stmt;

    if (sqlite3_prepare_v2(db, sql, -1, &stmt, NULL) == SQLITE_OK) {

        sqlite3_bind_text(stmt, 1, "母鸡", -1, NULL);

        sqlite3_bind_int(stmt, 2, 27);

    }

    if (sqlite3_step(stmt) != SQLITE_DONE) {

        NSLog(@"插入数据错误");

    }

    sqlite3_finalize(stmt);

     

    代码解析:

    sqlite3_prepare_v2()返回值等于SQLITE_OK,说明SQL语句已经准备成功,没有语法问题

     

    三、查询数据

    char *sql = "select id,name,age from t_person;";

    sqlite3_stmt *stmt;

    if (sqlite3_prepare_v2(db, sql, -1, &stmt, NULL) == SQLITE_OK) {

        while (sqlite3_step(stmt) == SQLITE_ROW) {

            int _id = sqlite3_column_int(stmt, 0);

            char *_name = (char *)sqlite3_column_text(stmt, 1);

            NSString *name = [NSString stringWithUTF8String:_name];

            int _age = sqlite3_column_int(stmt, 2);

            NSLog(@"id=%i, name=%@, age=%i", _id, name, _age);

        }

    }

    sqlite3_finalize(stmt);

     

    代码解析

    sqlite3_step()返回SQLITE_ROW代表遍历到一条新记录

    sqlite3_column_*()用于获取每个字段对应的值,第2个参数是字段的索引,从0开始

     

     

     

     

     

    SQLite函数总结

    一、打开数据库

    int sqlite3_open(

        const char *filename,   // 数据库的文件路径

        sqlite3 **ppDb          // 数据库实例

    );

     

    二、执行任何SQL语句

    int sqlite3_exec(

        sqlite3*,                                  // 一个打开的数据库实例

        const char *sql,                           // 需要执行的SQL语句

        int (*callback)(void*,int,char**,char**),  // SQL语句执行完毕后的回调

        void *,                                    // 回调函数的第1个参数

        char **errmsg                              // 错误信息

    );

     

    三、检查SQL语句的合法性(查询前的准备)

    int sqlite3_prepare_v2(

        sqlite3 *db,            // 数据库实例

        const char *zSql,       // 需要检查的SQL语句

        int nByte,              // SQL语句的最大字节长度

        sqlite3_stmt **ppStmt,  // sqlite3_stmt实例,用来获得数据库数据

        const char **pzTail

    );

     

    四、查询一行数据

    int sqlite3_step(sqlite3_stmt*); // 如果查询到一行数据,就会返回SQLITE_ROW

     

    五、利用stmt获得某一字段的值(字段的下标从0开始)

    double sqlite3_column_double(sqlite3_stmt*, int iCol);  // 浮点数据

    int sqlite3_column_int(sqlite3_stmt*, int iCol); // 整型数据

    sqlite3_int64 sqlite3_column_int64(sqlite3_stmt*, int iCol); // 长整型数据

    const void *sqlite3_column_blob(sqlite3_stmt*, int iCol); // 二进制文本数据

    const unsigned char *sqlite3_column_text(sqlite3_stmt*, int iCol);  // 字符串数据

    SQL语句

    /*简单约束*/

    CREATE TABLE IF NOT EXISTS t_student(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER);

    CREATE TABLE IF NOT EXISTS t_student(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, age INTEGER NOT NULL);

    CREATE TABLE IF NOT EXISTS t_student(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT UNIQUE, age INTEGER);

    CREATE TABLE IF NOT EXISTS t_student(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER DEFAULT 1);

     

    /*分页*/

    SELECT * FROM t_student ORDER BY id ASC LIMIT 30, 10;

     

    /*排序*/

    SELECT * FROM t_student WHERE score > 50 ORDER BY age DESC;

    SELECT * FROM t_student WHERE score < 50 ORDER BY age ASC , score DESC;

     

    /*计量*/

    SELECT COUNT(*) FROM t_student WHERE age > 50;

     

    /*别名*/

    SELECT name as myName, age as myAge, score as myScore FROM t_student;

    SELECT name myName, age myAge, score myScore FROM t_student;

    SELECT s.name myName, s.age myAge, s.score myScore FROM t_student s WHERE s.age > 50;

     

    /*查询*/

    SELECT name, age, score FROM t_student;

    SELECT * FROM t_student;

     

    /*修改指定数据*/

    UPDATE t_student SET name = 'MM' WHERE age = 10;

    UPDATE t_student SET name = 'WW' WHERE age is 7;

    UPDATE t_student SET name = 'XXOO' WHERE age < 20;

    UPDATE t_student SET name = 'NNMM' WHERE age < 50 and score > 10;

     

    /*删除数据*/

    DELETE FROM t_student;

     

    /*更新数据*/

    UPDATE t_student SET name = 'LNJ';

     

    /*插入数据*/

     

     INSERT INTO t_student(age, score, name) VALUES ('28', 100, 'jonathan');

     INSERT INTO t_student(name, age) VALUES ('lee', '28');

     INSERT INTO t_student(score) VALUES (100);

     

    /*插入数据*/

    INSERT INTO t_student(name, age, score) VALUES ('lee', '28', 100);

    /*添加主键*/

    CREATE TABLE IF NOT EXISTS t_student (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, score REAL);

    /*添加主键*/

    CREATE TABLE IF NOT EXISTS t_student (id INTEGER, name TEXT, age INTEGER, score REAL, PRIMARY KEY(id));

     

    /*删除表*/

    DROP TABLE IF EXISTS t_student;

     

    /*创建表*/

    CREATE TABLE IF NOT EXISTS t_student(id INTEGER , name TEXT, age , score REAL);

  • 相关阅读:
    Runtime类与Process类
    runtime 得到jvm的内存空间信息
    random 类的实际应用
    NumberFormat类实际应用
    java 国际化程序实现
    Calendar类取得系统的当前日期
    demo-文件复制
    用递归方法 在列表中 使用二分查找。找一个数字
    第一个 购物车程序
    练习题1 —— 全局替换程序
  • 原文地址:https://www.cnblogs.com/cleven/p/5424526.html
Copyright © 2011-2022 走看看