怎样在一个工程中使用sqlite

前端之家收集整理的这篇文章主要介绍了怎样在一个工程中使用sqlite前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

要转载请表明链接地址http://blog.sina.com.cn/bbsme

作者:Amor Yin(makaymose)

首先在工程加入框架 libsqlite3.dylib
在头文件里加入

#import"/usr/include/sqlite3.h"

下来按照我的习惯先把常用的字符串与定义出来,这是一个好的习惯

#define"data.sqlite3"

#define"Data"

sqlite3*database;//定义一个数据库字段

接下来我们初始化数据库


*找到目标数据库存在的位置

- (NSString*)dataFilePath

{

NSArray *paths =NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES);

NSString *documentsDirectory = [pathsobjectAtIndex:0];

return [documentsDirectorystringByAppendingPathComponent:kFilename];

}



nbsp;* 判断数据库是否存在能否正确打开

if (sqlite3_open([[self dataFilePath]UTF8String],&database) != sqlITE_OK) {

sqlite3_close(database);

NSAssert(0,@"Failed to open database");

}


* 如果数据库存在创建表格

char *errorMsg;

NSString *createsql= @"CREATE TABLE IF NOT EXISTS USERSINFO (NAME TEXT PRIMARYKEY,CONTEXT TEXT);";

if (sqlite3_exec(database,[createsqlUTF8String],NULL,&errorMsg) != sqlITE_OK) {

sqlite3_close(database);

NSAssert1(0,@"Error creating table: %s",errorMsg);

}

* 查询记录

NSString *query =@"SELECTNAME,CONTEXTFROMUSERSINFOORDERBYNAME";

sqlite3_stmt*statement;

if(sqlite3_prepare_v2( database,[queryUTF8String],-1,&statement,nil) == sqlITE_OK) {

while(sqlite3_step(statement) == sqlITE_ROW){

猜你在找的Sqlite相关文章