简介:
SQLite是遵守ACID的关系数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp创建的公有领域项目。
不像常见的客户端/服务器结构范例,SQLite引擎不是个程序与之通信的独立进程,而是连接到程序中成为它的一个主要部分。所以主要的通信协议是在编程语言内的直接API调用。这在消耗总量、延迟时间和整体简单性上有积极的作用。整个数据库(定义、表、索引和数据本身)都在宿主主机上存储在一个单一的文件中。它的简单的设计是通过在开始一个事务的时候锁定整个数据文件而完成的。
特征:
库实现了多数的SQL-92标准,包括事务,就是代表原子性、一致性、隔离性和持久性的(ACID),触发器和多数的复杂查询。不进行类型检查。你可以把字符串插入到整数列中。例如,某些用户发现这是使数据库更加有用的创新,特别是与无类型的脚本语言一起使用的时候。其他用户认为这是主要的缺点。
多个进程或线程可以同时访问同一个数据而没有问题。可以同时平行读取同一个数据库。但同一时间只能有一个进程或线程进行数据写入;否则会写入失败并得到一个错误信息(或者会自动重试一段时间,而这重试时间的长短是可以设置的)。
程序设计者还提供了一个叫做sqlite3的独立程序用来查询和管理SQLite数据库文件。SQLite的用户可以把这个程序当作如何写SQLite应用程序的示例。
用法:
语句:
查询语句:
删除语句:
NSString* changeDB=[NSString stringWithFormat:@"delete from yc_shopcar_sq where deleteState = '%@' ",@"1"];
插入语句:
NSString* updateDB=[NSString stringWithFormat:@"insert into yc_shopcar_sq(name,code,num,price,id,deleteState)values('%@','%@','%@','%@','%d',2)",nameString,numberText.text,numberString,priceString,cartId];
更新语句:
NSString* changeDB=[NSString stringWithFormat:@"update yc_shopcar_sq set deleteState = '%@' where orderId = '%@' ",@"1",[NSString stringWithFormat:@"%d",orderId]];