- 浏览: 659586 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
lizaochengwen:
网络请求碰到的中文乱码使用encodeURL吧- (NSStr ...
iPhone开发/iPad开发 中文乱码问题 -
hhb19900618:
还是没弄懂怎么解决了中文乱码? 正确代码能重写贴出吗
iPhone开发/iPad开发 中文乱码问题 -
zhengjj_2009:
我的理解是讲ipa文件解压缩之后再重新打包,已经破坏了签名,所 ...
xcodebuild和xcrun实现自动打包iOS应用程序 -
zhengjj_2009:
我参考你的“ 从ipa格式的母包生成其它渠道包的shell脚本 ...
xcodebuild和xcrun实现自动打包iOS应用程序 -
同一片天空:
问题果然解决了
iOS 搭建 XMPP实现环境
IOS应用中关于Sqlite使用是本文要介绍的内容,sqlite是嵌入式的和轻量级的sql数据库。sqlite是由c实现的。广泛用于包括浏览器,来看内容。
AD:
IOS应用中关于Sqlite使用是本文要介绍的内容,sqlite是嵌入式的和轻量级的sql数据库。sqlite是由c实现的。广泛用于包括浏览器(支持html5的大部分浏览器,ie除外)、IOS应用、android应用以及一些便携需求的小型web应用系统。
使用sqlite前的准备
使用sqlite是很多做ios应用开发中第一次面对c的情况,包括我。因为sqlite是c写的,objc可以直接使用c代码。在sqlite前,一般都会使用cocoa touch框架,都是基于objc的。
首先,需要在对应文件的头文件中加入:
#import "/usr/include/sqlite3.h"
并在Frameworks中加入所需的库,否则会报错:
Undefined symbols:
"_sqlite3_open", referenced from:
加入库的方法是:
选择sqlite库:
选择完的效果:
然后,应该有个成员变量,比如我的代码:
@interface DetailViewController : UIViewController <UIPopoverControllerDelegate, UISplitViewControllerDelegate> {
UIPopoverController *popoverController;
UIToolbar *toolbar;
id detailItem;
UILabel *detailDescriptionLabel;
sqlite3 *database;
打开数据库
sqlite数据库是文件数据库,是保存在文件系统中的。因此需要知道文件保存到哪里,可参见iOS应用中对文件的操作。比如本文保存到Documents目录下。代码:
NSArray *documentsPaths=NSSearchPathForDirectoriesInDomains(NSDocumentDirectory
, NSUserDomainMask
, YES);
NSString *databaseFilePath=[[documentsPaths objectAtIndex:0] stringByAppendingPathComponent:@"mydb"];
if (sqlite3_open([databaseFilePath UTF8String], &database)==SQLITE_OK) {
NSLog(@"open sqlite db ok.");
}
通过ssh查看Documents目录,发现mydb文件已经创建。sqlite的策略是如果有该文件就打开,如果没有就创建文件,也就是创建数据库。
这里要注意,使用的是c语法,sqlite3_open传入的是database的地址。
关闭数据库
数据库使用完毕后,要关闭,比如退出应用的时候:
- (void)viewDidUnload {
// Release any retained subviews of the main view.
// e.g. self.myOutlet = nil;
sqlite3_close(database);
self.popoverController = nil;
}
建表语句
数据库打开以后,如果没有表,建表:
char *errorMsg;
const char *createSql="create table if not exists persons (id integer primary key autoincrement,name text)";
if (sqlite3_exec(database, createSql, NULL, NULL, &errorMsg)==SQLITE_OK) {
NSLog(@"create ok.");
}
这里要特别注意errorMsg传的是地址,因为该函数要通过地址引用来写报错字符信息。
向表中插入记录
和建表语句类似:
const char *insertSql="insert into persons (name) values(‘张三’)";
if (sqlite3_exec(database, insertSql, NULL, NULL, &errorMsg)==SQLITE_OK) {
NSLog(@"insert ok.");
}
错误信息的处理
如果在多个地方使用errorMsg,那么每次使用完毕要清空一下字串,比如这样:
if (sqlite3_exec(database, createSql, NULL, NULL, &errorMsg)==SQLITE_OK) {
NSLog(@"create ok.");
}else {
NSLog(@"error: %s",errorMsg);
sqlite3_free(errorMsg);
}
查询结果集
结果集的查询,需要用到statement:
const char *selectSql="select id,name from persons";
sqlite3_stmt *statement;
if (sqlite3_prepare_v2(database, selectSql, -1, &statement, nil)==SQLITE_OK) {
NSLog(@"select ok.");
}
while (sqlite3_step(statement)==SQLITE_ROW) {
int _id=sqlite3_column_int(statement, 0);
char *name=(char *)sqlite3_column_text(statement, 1);
NSLog(@"row>>id %i, name %s",_id,name);
}
sqlite3_finalize(statement);
不过这里有个问题,看看打印的日志:
乱码。因为直接用的char类型来做的。
解决办法是,用nsstring替代char:
while (sqlite3_step(statement)==SQLITE_ROW) {
int _id=sqlite3_column_int(statement, 0);
NSString *name=[[NSString alloc] initWithCString:(char *)sqlite3_column_text(statement, 1) encoding:NSUTF8StringEncoding];
NSLog(@"row>>id %i, name %@",_id,name);
}
char生成nsstring的时候做一次显式的编码。问题解决:
这说明:
写入数据库,用char的方式没有问题,写入数据库的编码是对的;
从库中取出,可能默认使用ascii解码,造成显示乱码。
小结:IOS应用中关于Sqlite使用的内容介绍完了,希望通过本文的学习能对你有所帮助!
原文地址:http://mobile.51cto.com/iphone-288898.htm
AD:
IOS应用中关于Sqlite使用是本文要介绍的内容,sqlite是嵌入式的和轻量级的sql数据库。sqlite是由c实现的。广泛用于包括浏览器(支持html5的大部分浏览器,ie除外)、IOS应用、android应用以及一些便携需求的小型web应用系统。
使用sqlite前的准备
使用sqlite是很多做ios应用开发中第一次面对c的情况,包括我。因为sqlite是c写的,objc可以直接使用c代码。在sqlite前,一般都会使用cocoa touch框架,都是基于objc的。
首先,需要在对应文件的头文件中加入:
#import "/usr/include/sqlite3.h"
并在Frameworks中加入所需的库,否则会报错:
Undefined symbols:
"_sqlite3_open", referenced from:
加入库的方法是:
选择sqlite库:
选择完的效果:
然后,应该有个成员变量,比如我的代码:
@interface DetailViewController : UIViewController <UIPopoverControllerDelegate, UISplitViewControllerDelegate> {
UIPopoverController *popoverController;
UIToolbar *toolbar;
id detailItem;
UILabel *detailDescriptionLabel;
sqlite3 *database;
打开数据库
sqlite数据库是文件数据库,是保存在文件系统中的。因此需要知道文件保存到哪里,可参见iOS应用中对文件的操作。比如本文保存到Documents目录下。代码:
NSArray *documentsPaths=NSSearchPathForDirectoriesInDomains(NSDocumentDirectory
, NSUserDomainMask
, YES);
NSString *databaseFilePath=[[documentsPaths objectAtIndex:0] stringByAppendingPathComponent:@"mydb"];
if (sqlite3_open([databaseFilePath UTF8String], &database)==SQLITE_OK) {
NSLog(@"open sqlite db ok.");
}
通过ssh查看Documents目录,发现mydb文件已经创建。sqlite的策略是如果有该文件就打开,如果没有就创建文件,也就是创建数据库。
这里要注意,使用的是c语法,sqlite3_open传入的是database的地址。
关闭数据库
数据库使用完毕后,要关闭,比如退出应用的时候:
- (void)viewDidUnload {
// Release any retained subviews of the main view.
// e.g. self.myOutlet = nil;
sqlite3_close(database);
self.popoverController = nil;
}
建表语句
数据库打开以后,如果没有表,建表:
char *errorMsg;
const char *createSql="create table if not exists persons (id integer primary key autoincrement,name text)";
if (sqlite3_exec(database, createSql, NULL, NULL, &errorMsg)==SQLITE_OK) {
NSLog(@"create ok.");
}
这里要特别注意errorMsg传的是地址,因为该函数要通过地址引用来写报错字符信息。
向表中插入记录
和建表语句类似:
const char *insertSql="insert into persons (name) values(‘张三’)";
if (sqlite3_exec(database, insertSql, NULL, NULL, &errorMsg)==SQLITE_OK) {
NSLog(@"insert ok.");
}
错误信息的处理
如果在多个地方使用errorMsg,那么每次使用完毕要清空一下字串,比如这样:
if (sqlite3_exec(database, createSql, NULL, NULL, &errorMsg)==SQLITE_OK) {
NSLog(@"create ok.");
}else {
NSLog(@"error: %s",errorMsg);
sqlite3_free(errorMsg);
}
查询结果集
结果集的查询,需要用到statement:
const char *selectSql="select id,name from persons";
sqlite3_stmt *statement;
if (sqlite3_prepare_v2(database, selectSql, -1, &statement, nil)==SQLITE_OK) {
NSLog(@"select ok.");
}
while (sqlite3_step(statement)==SQLITE_ROW) {
int _id=sqlite3_column_int(statement, 0);
char *name=(char *)sqlite3_column_text(statement, 1);
NSLog(@"row>>id %i, name %s",_id,name);
}
sqlite3_finalize(statement);
不过这里有个问题,看看打印的日志:
乱码。因为直接用的char类型来做的。
解决办法是,用nsstring替代char:
while (sqlite3_step(statement)==SQLITE_ROW) {
int _id=sqlite3_column_int(statement, 0);
NSString *name=[[NSString alloc] initWithCString:(char *)sqlite3_column_text(statement, 1) encoding:NSUTF8StringEncoding];
NSLog(@"row>>id %i, name %@",_id,name);
}
char生成nsstring的时候做一次显式的编码。问题解决:
这说明:
写入数据库,用char的方式没有问题,写入数据库的编码是对的;
从库中取出,可能默认使用ascii解码,造成显示乱码。
小结:IOS应用中关于Sqlite使用的内容介绍完了,希望通过本文的学习能对你有所帮助!
原文地址:http://mobile.51cto.com/iphone-288898.htm
发表评论
-
SOCK_STREAM和SOCK_DGRAM
2015-07-23 20:08 1640sock_stream 是有保障的(即能保证数据正确传送到 ... -
SOCKET bind INADDR_LOOPBACK和INADDR_ANY的区别
2015-07-23 19:49 2057今天写程序时候,服务器端启动了,然后客户端总是连接不上,con ... -
htons()
2015-07-23 19:26 580在C/C++写网络程序的时候,往往会遇到字节的网络顺序和主机顺 ... -
使用symbolicatecrash分析crash文件
2015-03-10 11:32 1179原文 http://www.cnblogs.com/ning ... -
程序设计中的计算复用(Computational Reuse)
2015-02-10 10:18 662从斐波那契数列说起 ... -
didReceiveMemoryWarning
2015-02-09 16:11 541IPhone下每个app可用的内存是被限制的,如果一个app使 ... -
iOS开发中怎么响应内存警告
2015-02-09 16:08 654好的应用应该在系统内存警告情况下释放一些可以重新创建的资源。在 ... -
ASIHTTPRequest多次重复请求的问题
2014-12-17 14:34 641在一个车票订购的项目中,点击一次订购,却生成了2次订单,通过抓 ... -
从 CloudKit 看 BaaS 服务的趋势
2014-09-26 11:51 726从 6 月份 WWDC 苹果发布 ... -
ios编程--AVCapture编程理解
2014-09-26 11:03 9230、媒体采集的几个东西。这里所需要明白的是,在这个流程中,这里 ... -
NSURLProtocol
2014-09-25 10:42 8191、http://nshipster.com/nsurlpro ... -
关于iOS8的extension插件
2014-09-25 10:41 1279关于iOS8的extension插件,有兴趣的同学可以参考一下 ... -
【转】ios app在itunesConnect里面的几种状态
2014-08-05 10:34 1145Waiting for Upload (Yellow) Ap ... -
[转]iOS Dev (45) iOS图标与切片处理工具Prepo
2014-02-07 17:02 1034iOS Dev (45) iOS图标与切片处理工具Prepo ... -
phoneGap开发IOS,JS调用IOS方法/phoneGap插件开发
2014-01-13 17:49 1244前沿 废话不说phoneGap是什么不多介绍,官方网站: h ... -
如何在IOS平台下搭建PhoneGap开发环境(PhoneGap2.5)
2014-01-13 15:23 747由于在下最近在做基于HTML5的跨平台移植,搭建环境的时候着实 ... -
xcode 4 制作静态库详解
2013-12-20 18:27 533最近在做Apple的IOS开发,有开发静态库的需求,本身IOS ... -
【翻译】ios教程-创建静态库
2013-12-20 18:19 3108作者:shede333 主页:htt ... -
封装自己的控件库:iPhone静态库的应用
2013-12-20 17:03 581由于iPhone 控件的极度匮乏和自定义组件在重用上的限制,在 ... -
iphone:使用NSFileManager取得目录下所有文件(遍历所有文件)
2013-11-18 17:56 869From:http://note.sdo.com/u/xiao ...
相关推荐
本教程将深入探讨如何在iOS项目中简单应用SQLite3,包括数据的保存、查询、插入和更新。 首先,你需要在Xcode项目中导入SQLite3框架。这可以通过在项目设置的“Link Binary With Libraries”部分添加`libsqlite3....
本篇文章将详细讲解如何在iOS应用中使用SQLite3进行数据管理,并实现简单的搜索功能。 一、SQLite3的集成 在iOS项目中,我们首先需要将SQLite3库引入。虽然iOS系统已经内置了SQLite3,但为了方便使用,我们通常会...
2. **iOS中的SQLite集成**:在iOS应用中使用SQLite,首先需要添加SQLite库到项目中。Xcode可以通过CocoaPods或Carthage等依赖管理工具进行集成,也可以手动将SQLite动态库添加到项目文件中。 3. **数据库操作**: ...
总的来说,这个示例会展示如何在iOS应用中使用SQLite进行数据存储,并通过`Masonry`进行UI布局,帮助开发者理解这两个工具的用法。在实践中,你可以学习到如何创建数据库连接、执行SQL语句、更新UI以反映数据库的...
在iOS开发中,SQLite是一个非常重要的数据存储工具,它是一个轻量级的、关系型的数据库,被广泛应用于移动应用中。...通过研究这个示例,你可以更好地理解如何在实际的iOS应用中使用SQLite数据库。
在iOS应用中,通常会在应用程序的沙盒目录下创建SQLite数据库文件。以下是一个简单的Objective-C示例,展示如何打开或创建一个新的SQLite数据库: ```objc NSString *docsDir; NSArray *dirPaths; // 获取文档目录...
本文将详细介绍如何在iOS应用中使用SQLite实现UI界面的增、删、改、查功能,并对SQLite进行简单的封装。 首先,我们需要了解SQLite的基本概念。SQLite是一个自包含、无服务器、零配置、事务型的SQL数据库引擎,可以...
FMDB是iOS应用开发中广泛使用的SQLite数据库管理库,它为开发者提供了一个高效且易于使用的接口,以便在Objective-C或Swift项目中与SQLite数据库进行交互。这个开源库由Cocoa社区的知名开发者Mike Ash开发,并得到了...
这个“iOS sqlite3基本项目”可能是为了帮助初学者通过实践学习如何在iOS应用中直接操作SQLite3数据库,通过编写简单的CRUD(创建、读取、更新、删除)操作,加深对SQLite3的理解。你可以从项目中查看如何将这些步骤...
Base作为一个图形化用户界面(GUI)应用,使得开发者无需通过命令行终端就能便捷地操作SQLite数据库,大大提升了iOS应用开发过程中的数据库管理工作效率。 描述中提到的“MAC 下的数据库管理软件”,意味着Base是...
SQLite是一款轻型的嵌入式数据库,它不需要单独的服务器进程,可以直接嵌入到iOS应用中,为开发者提供了简单且高效的数据管理方式。 SQLite的核心特性包括: 1. **小巧轻便**:SQLite数据库引擎非常小,可以嵌入到...
"ios-SQLite数据库简易存储.zip" 文件提供了一个简单封装的SQLite3库,使得在iOS应用中操作SQLite变得更加便捷。 1. SQLite简介: SQLite是一个开源的嵌入式数据库,它不需要单独的服务器进程,可以直接在应用程序...
SQLite是一个轻量级、嵌入式的数据库,非常适合iOS应用。它不需要单独的服务器进程,可以直接在应用中使用,降低了内存和CPU的资源消耗。SQLite支持SQL标准,并提供了事务处理、备份、恢复等功能,确保数据的安全性...
在iOS中使用SQLite,通常需要以下步骤: 1. **安装SQLite库**:尽管iOS系统内置了SQLite,但为了方便编程,开发者通常会使用第三方库如FMDB,它是Objective-C编写的SQLite封装库,提供了简单易用的API。 2. **创建...
SQLite是一个嵌入式数据库,它不需要单独的服务进程,可以直接在应用程序中使用。它的API可以被集成到各种编程语言中,包括Objective-C,这是iOS应用的主要开发语言。 在iOS中,SQLite数据库通常通过SQLite Manager...
在iOS应用中使用SQLite,开发者通常会使用Core Data框架,它是苹果提供的一个高级对象持久化框架,可以方便地管理SQLite数据库。不过,如果直接操作SQLite,可以使用FMDB这样的Objective-C或Swift库,它提供了一个...
总之,Facebook的iOS SQLite封装框架为开发者提供了一个强大且易用的工具,简化了iOS应用中的数据库管理。它通过对象映射和高级查询接口,使数据库操作更加直观,降低了开发难度,提高了代码的可读性和可维护性。
在这个名为"IOS应用源码之【框架】SQLite for iOS.rar"的压缩包中,你将找到关于如何在iOS项目中集成和使用SQLite的相关源码示例。 SQLite是一个开源的关系型数据库,它的核心特性包括事务处理、SQL支持和强大的...
SQLite的功能虽然较为简单,但足以支持大多数iOS应用的数据存储需求。 书中应该会涉及如何在iOS应用中集成SQLite数据库,包括数据库的创建、数据表的建立和管理、以及数据的查询、插入、更新和删除等操作。同时,...
本示例将介绍如何在iOS应用中使用Firefox SQLite Manager来管理和操作SQLite数据库。 首先,我们需要理解SQLite在iOS中的工作原理。SQLite是一个嵌入式数据库,它不依赖于单独的服务进程,而是直接与应用程序集成。...