SQLite3使用:
insert data
sqlite3_open
sqlite3_stmt
sqlite3_prepare_v2
sqlite3_bind_text
sqlite3_step
sqlite3_finalize
sqlite3_close
query data
sqlite3_open
sqlite3_stmt初始化缓存区
sqlite3_prepare_v2执行查询语句
sqlite3_step while循环逐步执行sqlite_step(stmt)如果stmt中还有未读取的数据返回SQLITE_ROW如读取完毕返回SQLITE_DON
sqlite3_column_datatype
sqlite3_finalize释放缓冲区
sqlite3_close关闭数据库
打开sqlite3_open参数1数据库文件路径参数2数据库指针的地址如果数据库不存在该方法会创建一个数据库并打开
如果打开失败关闭数据库
断言NSAssert(条件,….)如果条件为假crash崩溃并输出字符串
断言表达式不成立程序crash打印输出
创建表
sql语句execute
sqlite3_exec(sqlite3 *, const char *sql, int (*callback)(void *, int, char **, char **), void *, char **errmsg)
sqlite3_exec 参数1sqlite3 * 数据库; 参数2char *sql sql语句转化的C字符串; 参数3*callbackC语言的回调方法; 参数4void *回调方法的第一个参数. 参数5**errmsg错误信息双指针
存数据
打开数据库sqlite3_open
创建sql语句
初始化句柄sqlite3_stmt *stmt = NULL
准备存数据sqlite3_prepare_v2把SQL语句编译成字节码留给后面的执行函数(不执行)
sqlite3_prepare_v2(sqlite3 *db, const char *zSql, int nByte, sqlite3_stmt **ppStmt, const char **pzTail)
sqlite3_prepare_v2(db, [checkIsHaveSql UTF8String], -1, &stmt, nil)
db:数据库句柄
zSql:语句
nByte:如果nByte小于0,则函数取出zSql从开始到第一0终止符的内容l如果nByte不是负的,那么它就是这个函数能从zSql中读取的字节数的最大值。
pZtail:上面提到zSql在遇见终止符或者是达到设定的nByte之后结束,假如zSql还有剩余的内容,那y这些剩余的内容被存放到pZtail中,不包括终止符
ppStmt:能够使用sqlite3_step()执行的编译好的准备语句的句柄,如果错误发生,它被置为NULL,如假如输入的文本不包括sql语句。调用过程必须负责在编译好的sql语句完成使用后使用sqlite3_finalize()删除stmt中的内容。
向stmt中绑定内容sqlite3_bind_datatype 1、句柄2、字段索引从1开始3、值4、值长度5、函数指针不需要传null
执行stmt即编译好的sql语句获得结果的一行sqlite3_step返回SQLITE_DONE
释放缓冲区sqlite3_finalize
关闭数据库sqlite3_close
读数据
打开数据库sqlite3_open
创建sql语句
初始化缓存区sqlite3_stmt *stmt = NULL
准备执行查询语句sqlite3_prepare_v2
while循环逐步执行sqlite_step(stmt)如果stmt中还有未读取的数据返回SQLITE_ROW如读取完毕返回SQLITE_DONE
取数据sqlite3_column_datatype索引从0开始
释放缓冲区sqlite_finalize
关闭数据库sqlite_close
SQLite语句四中数据类型:
Int 整型 text文本字符串real 浮点型bool 存放较大的二进制数据
1.创建表
CREAT TABLE 表名(字段1,字段2,字段3)
exp:CREAT TABLE Teacher (name text, age int, sex text);
2.插入一条数据
INSERT INTO 表名(字段1,字段2,字段3)VALUES (值1,值2,值3)
值要和字段一一对应 且不能少 为文本的字段时 加引号(单双皆可)浮点型不用
3.查询数据
SELECT 字段 FROM 表名
SELECT 字段,字段,字段 FROM 表名
SELECT * FROM 表名
WHERE语句用于有条件地从表中选取数据可将WHERE子句添加到SELECT语句
语法
在SELECT查询语句后+WHERE字段名运算符值
SELECT*FROMStudentsWHEREname = '张三';
数据库提供内置函数:MAX(最大值), MIN(最小值), AVG(平均值)SUM(总值)
SELECT MAX(字段名) FROM表名
SELECT*FROMStudentsWHEREageBETWEEN10AND100
运算符有=,<>(不等于!=),>,<,>=,<=,BETWEEN(在某个范围内前闭后闭),LIKE(搜索某种模式%可以代表任意一串字符_代表一个任意字符)
abcd
_b%
查询有d的字符串%d%
SELECT*FROMAAAWHEREcolumn1LIKE'%d%'
查询第二位有b的字符串_b%
SELECT*FROMAAAWHEREcolumn1LIKE'_b%'
引号:SQL使用单引号(也支持双引号)来环绕文本值。如果是数值,则不要使用引号
4.修改数据
UPDATE表名称SET列名称=新值WHERE列名称=某值(where后是一个条件)
UPDATE表名称SET列名称=新值,列名称=新值WHERE列名称=某值
5.删除数据
DELETE用于删除表中的行
语法:
DELETE FROM表名称WHERE列名称=值
DELETEFROMStudentsWHEREname = '小芳'
删除所有行即在不删除表的情况下删除所有的行,表的结构、索引、字段都是完整的
DELETE FROM表名
DELETEFROMTeacher
6.约束
SQL约束用于限制加入表的数据的类型。可以在创建表时规定约束,或者表创建过后也可以,主要有以下几种约束
NOT NULL约束强制列不接受空值空值无法插入新纪录或更新纪录
UNIQUE约束唯一标识数据库表中的某个字段
PRIMARY KEY主键每个表中都应有且只能有一个主键主键列不能为NULL值
FOREIGN KEY外键关键表
DEFAULT给字段添加默认值
AUTOINCREMENT自动增长
7.查询不重复的数据
SELECT DISTINCT列名称FROM表名称
SELECTDISTINCTnameFROMStudents
SELECTDISTINCT*FROMStudents
8.AND和OR
如果两个条件都成立AND运算符返回一条数据
SELECT*FROMStudentsWHEREname='张三'ANDweight = '50'
只要一个条件成立OR运算符就返回一条数据
SELECT*FROMStudentsWHEREname='张三'ORweight = ’50'
9.OREDR BY
根据指定列对结果集进行排序默认按照升序对记录进行排序降序使用关键字DESC升序ASC
的 ORDER BY子句是用来递增或递减的顺序,根据一个或多个列中的数据进行排序。
SELECT字段名FROM表名称ORDER BY字段名条件(DESC或ASC)
SELECT字段名,字段名FROM表名称ORDER BY字段名条件,字段名条件(DESC或ASC)
SELECT*FROMStudentsORDERBYnameDESC, ageDESC
select *from students order by name desc,age desc
select age,name fromstudents order by age desc,name desc