`
lizaochengwen
  • 浏览: 660114 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

IOS应用中关于Sqlite简单使用

 
阅读更多
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
分享到:
评论

相关推荐

    iOS sqlite3的简单应用

    本教程将深入探讨如何在iOS项目中简单应用SQLite3,包括数据的保存、查询、插入和更新。 首先,你需要在Xcode项目中导入SQLite3框架。这可以通过在项目设置的“Link Binary With Libraries”部分添加`libsqlite3....

    ios sqlite3的简单使用和搜索功能

    本篇文章将详细讲解如何在iOS应用中使用SQLite3进行数据管理,并实现简单的搜索功能。 一、SQLite3的集成 在iOS项目中,我们首先需要将SQLite3库引入。虽然iOS系统已经内置了SQLite3,但为了方便使用,我们通常会...

    IOS SQLITE数据库访问与使用demo

    2. **iOS中的SQLite集成**:在iOS应用中使用SQLite,首先需要添加SQLite库到项目中。Xcode可以通过CocoaPods或Carthage等依赖管理工具进行集成,也可以手动将SQLite动态库添加到项目文件中。 3. **数据库操作**: ...

    ios-Sqlite 使用范例.zip

    总的来说,这个示例会展示如何在iOS应用中使用SQLite进行数据存储,并通过`Masonry`进行UI布局,帮助开发者理解这两个工具的用法。在实践中,你可以学习到如何创建数据库连接、执行SQL语句、更新UI以反映数据库的...

    IOS sqlite数据库操作

    在iOS开发中,SQLite是一个非常重要的数据存储工具,它是一个轻量级的、关系型的数据库,被广泛应用于移动应用中。...通过研究这个示例,你可以更好地理解如何在实际的iOS应用中使用SQLite数据库。

    IOS开发SQLite使用实例

    在iOS应用中,通常会在应用程序的沙盒目录下创建SQLite数据库文件。以下是一个简单的Objective-C示例,展示如何打开或创建一个新的SQLite数据库: ```objc NSString *docsDir; NSArray *dirPaths; // 获取文档目录...

    IOS sqlite 完成增删改查

    本文将详细介绍如何在iOS应用中使用SQLite实现UI界面的增、删、改、查功能,并对SQLite进行简单的封装。 首先,我们需要了解SQLite的基本概念。SQLite是一个自包含、无服务器、零配置、事务型的SQL数据库引擎,可以...

    FMDB ios sqlite开源库

    FMDB是iOS应用开发中广泛使用的SQLite数据库管理库,它为开发者提供了一个高效且易于使用的接口,以便在Objective-C或Swift项目中与SQLite数据库进行交互。这个开源库由Cocoa社区的知名开发者Mike Ash开发,并得到了...

    iOS sqlite app

    这个“iOS sqlite3基本项目”可能是为了帮助初学者通过实践学习如何在iOS应用中直接操作SQLite3数据库,通过编写简单的CRUD(创建、读取、更新、删除)操作,加深对SQLite3的理解。你可以从项目中查看如何将这些步骤...

    IOS 开发中用到的数据库SQLite管理软件 Base

    Base作为一个图形化用户界面(GUI)应用,使得开发者无需通过命令行终端就能便捷地操作SQLite数据库,大大提升了iOS应用开发过程中的数据库管理工作效率。 描述中提到的“MAC 下的数据库管理软件”,意味着Base是...

    ios-SQLite.zip

    SQLite是一款轻型的嵌入式数据库,它不需要单独的服务器进程,可以直接嵌入到iOS应用中,为开发者提供了简单且高效的数据管理方式。 SQLite的核心特性包括: 1. **小巧轻便**:SQLite数据库引擎非常小,可以嵌入到...

    ios-SQLite数据库简易存储.zip

    "ios-SQLite数据库简易存储.zip" 文件提供了一个简单封装的SQLite3库,使得在iOS应用中操作SQLite变得更加便捷。 1. SQLite简介: SQLite是一个开源的嵌入式数据库,它不需要单独的服务器进程,可以直接在应用程序...

    iOS数据库操作,SQLite操作和MySQL操作的实例.zip

    SQLite是一个轻量级、嵌入式的数据库,非常适合iOS应用。它不需要单独的服务器进程,可以直接在应用中使用,降低了内存和CPU的资源消耗。SQLite支持SQL标准,并提供了事务处理、备份、恢复等功能,确保数据的安全性...

    iOS开发SQLite数据库demo

    在iOS中使用SQLite,通常需要以下步骤: 1. **安装SQLite库**:尽管iOS系统内置了SQLite,但为了方便编程,开发者通常会使用第三方库如FMDB,它是Objective-C编写的SQLite封装库,提供了简单易用的API。 2. **创建...

    ios应用源码之使用火狐sqlite manager管理数据库的例子 untitled 2018127

    SQLite是一个嵌入式数据库,它不需要单独的服务进程,可以直接在应用程序中使用。它的API可以被集成到各种编程语言中,包括Objective-C,这是iOS应用的主要开发语言。 在iOS中,SQLite数据库通常通过SQLite Manager...

    ios应用源码之全国省市区 数据库 sqlite的,省、市、区都有 2018127

    在iOS应用中使用SQLite,开发者通常会使用Core Data框架,它是苹果提供的一个高级对象持久化框架,可以方便地管理SQLite数据库。不过,如果直接操作SQLite,可以使用FMDB这样的Objective-C或Swift库,它提供了一个...

    iOS中SQLite的封装(来源于Facebook开源框架)

    总之,Facebook的iOS SQLite封装框架为开发者提供了一个强大且易用的工具,简化了iOS应用中的数据库管理。它通过对象映射和高级查询接口,使数据库操作更加直观,降低了开发难度,提高了代码的可读性和可维护性。

    IOS应用源码之【框架】SQLite for iOS.rar

    在这个名为"IOS应用源码之【框架】SQLite for iOS.rar"的压缩包中,你将找到关于如何在iOS项目中集成和使用SQLite的相关源码示例。 SQLite是一个开源的关系型数据库,它的核心特性包括事务处理、SQL支持和强大的...

    Learning SQLite for iOS 无水印pdf 0分

    SQLite的功能虽然较为简单,但足以支持大多数iOS应用的数据存储需求。 书中应该会涉及如何在iOS应用中集成SQLite数据库,包括数据库的创建、数据表的建立和管理、以及数据的查询、插入、更新和删除等操作。同时,...

    IOS应用源码之使用火狐sqlite Manager管理数据库的例子 .zip

    本示例将介绍如何在iOS应用中使用Firefox SQLite Manager来管理和操作SQLite数据库。 首先,我们需要理解SQLite在iOS中的工作原理。SQLite是一个嵌入式数据库,它不依赖于单独的服务进程,而是直接与应用程序集成。...

Global site tag (gtag.js) - Google Analytics