我的第一个iphonet小程序诞生!
经过一周的时间,终于完成了我的第一个iphone程序,暂时出名叫PocketWord,简称PW。它是一个简单的单词手册程序,目前功能是:可以开关单词解释,当关闭单词解释时,被选择单词会显示涵义。 上面是程序的界面,非常的简单,但还是在使用sqlite3时费了我不少周折,现在总结一下完成这个程序中遇到的问题,做个纪念。 单词都是放在sqlite3数据库文件中的,在xcode中使用的#import <sqlite3.h>导入头文件,以C函数的形式调用使用。 问题1. 导入sqlite3动态连接库
问题2. 数据库文件的存放,与复制。 sqlite3动态连接问题前,在模拟器中运行的时候还遇到一个问题,就是在使用sqlite3_prepare_v2函数执行sql查询时总是返回1,意思是表不存在,但调试打开数据库是正常的。我又反复在终端上使用sqlite3命令行程序反复验证过sql是对的,表是也是有的。分析了一下: 1.sqlite在使用上不对; 2.要不就是数据库文件不对. 我在打开数据库之前使用代码检查一下db文件是否存,打印出文件大小: //取得document路径数组 NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDirectory,YES); //取得一个为当前程序的document目录 NSString *documentDirectory = [pathsobjectAtIndex:0]; //组装db文件名。 self.dbFileName = [documentDirectorystringByAppendingPathComponent:@"vocabulary.db"]; if (self.dbFileName == nil) //文件不存在退出 return; //创建文件管理器 NSFileManager *fileManager = [NSFileManagerdefaultManager]; //取得文件属性,返回一个字典对象 NSDictionary * attributes = [fileManagerattributesOfItemAtPath:self.dbFileName error:nil]; //从字典里查询NSFileSize,取文件大小 NSNumber *theFileSize = [attributesobjectForKey:NSFileSize]; NSLog(@"%dbfile: @,size: %d",self.dbFileName,theFileSize); if(theFileSize == 0) return; 调试程序发现,我的db文件大小为0,这是因为sqlite3_open函数在发现指定的文件不存在时,会自动生成。我的db文件不documneth目录下,必使用代码将使用到的资源文件拷贝到document下: //使用NSBundle来取得工程中的db文件路径。 NSString *dbFile = [NSBundle mainBundle] pathForResource:@"vocabulary"ofType:@"db"]; [fileManager copyItemAtPath: dbFiletoPath: self.dbFileName error:nil];至此才将db文件复制到环境下,数据库问题终于解决了。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |