SQLite(数据库)简析
来源:互联网 发布:做好网络舆情工作 编辑:程序博客网 时间:2024/06/08 02:05
1.// 使用前需要引入 注意是<>括号,不是双引号
#import <sqlite3.h>
2、sqlite 的方法
sqlite3 *db, 数据库句柄,跟文件句柄FILE很类似
sqlite3_stmt *stmt, 这个相当于ODBC的Command对象,用于保存编译好的SQL语句
sqlite3_open(), 打开数据库,没有数据库时创建。
sqlite3_exec(), 执行非查询的sql语句
sqlite3_prepare(), 准备sql语句,执行select语句或者要使用parameter bind时,用这个函数(封装了sqlite3_exec).
Sqlite3_step(), 在调用sqlite3_prepare后,使用这个函数在记录集中移动。
Sqlite3_close(), 关闭数据库文件
还有一系列的函数,用于从记录集字段中获取数据,如
sqlite3_column_text(), 取text类型的数据。
sqlite3_column_blob(),取blob类型的数据
sqlite3_column_int(), 取int类型的数据
3.
/*
简单基本的sql语句
(1) 数据记录筛选:
sql=”select * from 数据表 where 字段名=字段值 order by 字段名 [desc]”
sql=”select * from 数据表 where 字段名 like ‘%字段值%’ order by 字段名 [desc]”
sql=”select top 10 * from 数据表 where 字段名=字段值 order by 字段名 [desc]”
sql=”select top 10 * from 数据表 order by 字段名 [desc]”
sql=”select * from 数据表 where 字段名 in (‘值1’,’值2’,’值3’)”
sql=”select * from 数据表 where 字段名 between 值1 and 值2”
(2) 更新数据记录:
sql=”update 数据表 set 字段名=字段值 where 条件表达式”
sql=”update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式”
(3) 删除数据记录:
sql=”delete from 数据表 where 条件表达式”
sql=”delete from 数据表” (将数据表所有记录删除)
(4) 添加数据记录:
sql=”insert into 数据表 (字段1,字段2,字段3 …) values (值1,值2,值3 …)”
sql=”insert into 目标数据表 select * from 源数据表” (把源数据表的记录添加到目标数据表)
(5) 数据记录统计函数:
AVG(字段名) 得出一个表格栏平均值
COUNT(*;字段名) 对数据行数的统计或对某一栏有值的数据行数统计
MAX(字段名) 取得一个表格栏最大的值
MIN(字段名) 取得一个表格栏最小的值
SUM(字段名) 把数据栏的值相加
引用以上函数的方法:
sql=”select sum(字段名) as 别名 from 数据表 where 条件表达式”
//set rs=conn.excute(sql)
用 rs(“别名”) 获取统计的值,其它函数运用同上。
查询去除重复值:select distinct * from table1
(6) 数据表的建立和删除:
CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… )
*/
4.
一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。SQLite具有以下五种数据类型:
1.NULL:空值。
2.INTEGER:带符号的整型,具体取决有存入数字的范围大小。
3.REAL:浮点数字,存储为8-byte IEEE浮点数。
4.TEXT:字符串文本。
5.BLOB:二进制对象。
但实际上,sqlite3也接受如下的数据类型:
smallint 16 位元的整数。
interger 32 位元的整数。
decimal(p,s) p 精确值和 s 大小的十进位整数,精确值p是指全部有几个数(digits)大小值,s是指小数点後有几位数。如果没有特别指定,则系统会设为 p=5; s=0 。
float 32位元的实数。
double 64位元的实数。
char(n) n 长度的字串,n不能超过 254。
varchar(n) 长度不固定且其最大长度为 n 的字串,n不能超过 4000。
graphic(n) 和 char(n) 一样,不过其单位是两个字元 double-bytes, n不能超过127。这个形态是为了支援两个字元长度的字体,例如中文字。
vargraphic(n) 可变长度且其最大长度为 n 的双字元字串,n不能超过 2000
date 包含了 年份、月份、日期。
time 包含了 小时、分钟、秒。
timestamp 包含了 年、月、日、时、分、秒、千分之一秒。
datetime 包含日期时间格式,必须写成’2010-08-05’不能写为’2010-8-5’,否则在读取时会产生错误!
char、varchar、text和nchar、nvarchar、ntext的区别
1、CHAR。CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间,不足的自动用空格填充。
2、VARCHAR。存储变长数据,但存储效率没有CHAR高。如果一个字段可能的值是不固定长度的,我们只知道它不可能超过10个字符,把它定义为 VARCHAR(10)是最合算的。VARCHAR类型的实际长度是它的值的实际长度+1。为什么“+1”呢?这一个字节用于保存实际使用了多大的长度。从空间上考虑,用varchar合适;从效率上考虑,用char合适,关键是根据实际情况找到权衡点。
3、TEXT。text存储可变长度的非Unicode数据,最大长度为2^31-1(2,147,483,647)个字符。
4、NCHAR、NVARCHAR、NTEXT。这三种从名字上看比前面三种多了个“N”。它表示存储的是Unicode数据类型的字符。我们知道字符中,英文字符只需要一个字节存储就足够了,但汉字众多,需要两个字节存储,英文与汉字同时存在时容易造成混乱,Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示。nchar、nvarchar的长度是在1到4000之间。和char、varchar比较起来,nchar、nvarchar则最多存储4000个字符,不论是英文还是汉字;而char、varchar最多能存储8000个英文,4000个汉字。可以看出使用nchar、nvarchar数据类型时不用担心输入的字符是英文还是汉字,较为方便,但在存储英文时数量上有些损失。
所以一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar。
5.代码部分
// 创建数据库
#pragma mark 打开创建数据库
- (void)openDataBase { // 创建并打开数据库 // 获取数据库的路径 NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0]; // 设置数据库的路径和名词 NSString *dataBasePath = [[NSString alloc] initWithString:[documentPath stringByAppendingPathComponent:@"sqlite.sqlite"]]; // 创建并打开数据库 //sqlite3_open(), 打开数据库,没有数据库时创建。 int result = sqlite3_open([dataBasePath UTF8String], &db); if (result == SQLITE_OK) { NSLog(@"数据库打开成功"); } else { NSLog(@"数据库打开失败。。。。。。"); }}// 创建数据表#pragma mark 创建数据表- (void)createTabels { // sql语句 char *sql = "create table if not exists t_persons (id integer primary key autoincrement, name text, age integer);"; // 用于保存错误信息 char *error; // 执行创建语句并接收结果 //sqlite3_exec(), 执行非查询的sql语句 int result = sqlite3_exec(db, sql, NULL, NULL, &error); // 判断是否创建成功 if (result != SQLITE_OK) { NSLog(@"创建数据表失败~~~~~~~~:%s", error); } else { NSLog(@"数据表创建成功"); }}// 插入数据#pragma mark 插入数据- (void)insertData { // sql语句 char *sql = "insert into t_persons(name, age) values(@"张三", "20")"; // 存储的内容 sqlite3_stmt *stmt; // 执行语句并接收结果 //sqlite3_prepare(), 准备sql语句,执行select语句或者要使用parameter bind时,用这个函数(封装了sqlite3_exec). int result = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL); // 判断是否成功 if (result == SQLITE_OK) { // 语法通过 // 绑定数据 sqlite3_bind_text(stmt, 1, "lidaze", -1, NULL); sqlite3_bind_int(stmt, 2, 10); // 执行插入语句 if (sqlite3_step(stmt) == SQLITE_DONE) { NSLog(@"插入成功。。。。。"); } else { NSLog(@"插入失败"); } } else { NSLog(@"语法不通过 "); } // 释放stmt sqlite3_finalize(stmt);}// 查找数据#pragma mark 查找数据- (void)findData { // 准备C语言sql语句 char *sql = "select * from t_persons"; // 准备stmt sqlite3_stmt *stmt; // 判断sql语句,并接收结果 int result = sqlite3_prepare_v2(db, sql, -1, &stmt, NULL); // 判断结果 if (result == SQLITE_OK) { // sql语句正确 NSLog(@"sql语句正确"); // 进行逐行读取内容 while (sqlite3_step(stmt) == SQLITE_ROW) { int ID = sqlite3_column_int(stmt, 0); char *name = (char *)sqlite3_column_text(stmt, 1); int age = sqlite3_column_int(stmt, 2); NSLog(@"id:%i, name:%s, age:%i", ID, name, age); } } else { NSLog(@"sql语句错误"); }}// 删除数据#pragma mark 删除数据- (void)deleteData { // 准备sql语句 char *sql = "delete from t_persons where id = ?"; // stmt sqlite3_stmt *stmt; // 判断sql语句 int result = sqlite3_prepare(db, sql, -1, &stmt, NULL); // 判断sql语句时候通过 if (result == SQLITE_OK) { NSLog(@"删除语句正确"); // 绑定数据 sqlite3_bind_int(stmt, 1, 58); // 判断时候执行成功 if (sqlite3_step(stmt) == SQLITE_DONE) { NSLog(@"删除成功"); } else { NSLog(@"删除是吧i"); } } else { NSLog(@"删除语句错误"); }}// 修改数据#pragma mark 修改数据- (void)updateData { // 准备C语言sql语句 char *sql = "update t_persons set name = ?, age=18 where id = ?;"; // 准备stmt sqlite3_stmt *stmt; // 执行sql语句的判断 int result = sqlite3_prepare(db, sql, -1, &stmt, NULL); // 判断sql语句时候可用 if (result == SQLITE_OK) { NSLog(@"修改语句正确"); // 绑定数据 sqlite3_bind_text(stmt, 1, "Zeeeeeeeeeee", -1, NULL); sqlite3_bind_int(stmt, 2, 62); // 执行并判断结果 if (sqlite3_step(stmt) == SQLITE_DONE) { NSLog(@"修改成功"); } else { NSLog(@"修改失败...."); } } else { NSLog(@"修改语句错误...."); }}
- SQLite(数据库)简析
- 数据库(sqlite)
- SQLite数据库(一)
- SQLite数据库(上)
- SQLite数据库(下)
- SQLite数据库(上)
- SQLite数据库(下)
- sqlite 数据库加密(SQLCipher)
- sqlite 数据库加密(SQLCipher)
- Android SQLite数据库(一 )
- unity sqlite数据库(一)
- Sqlite数据库总结(SQLiteOpenHelper)
- HTML5基础(SQLite数据库)
- SQLite---SQLite数据库简介
- Android数据库 之 SQLite数据库(一)
- Android数据库 之 SQLite数据库(二)
- Qt数据库开发实例(sqlite数据库)
- Sqlite 数据库
- Instant Complexity--模拟
- PHP基本类型boolean
- 一道题构建二叉树编译不同的思考
- Android 自动更新之状态栏下载状态和进度
- 读书感悟
- SQLite(数据库)简析
- bzoj 3956: Count (单调栈+st表)
- 单独HornetQ启动HornetQ
- C语言基本教程 第13课:标准库函数的使用
- 关于sql server char,nchar,varchar,nvarchar的区别
- 自定义控件(一):组合控件的使用
- git中rejected的解决方法
- 在页面添加编译信息
- 【Linux】在Ubuntu中布置LAMP环境