iOS中sqlite数据库的原生用法
在ios中,也同样支持sqlite。目前有很多第三方库,封装了sqlite操作,比如swift语言写的sqlite.swift、苹果官网也为我们封装了一个框架:coredata。
它们都离不开sqlite数据库的支持。
本文主要介绍下,如何在swift中使用原生的sqlite的api。
在xcode中引入sqlite api
新建一个swift项目后,我们需要让项目引入sqlite的动态链接库:
1、项目配置界面,选择build phases
2、点开link binary with libraries,点击+号,在弹窗中输入sqlite3
完成后:
3、创建桥接文件,在项目目录下新建一个头文件(h):
4、然后使用import导入sqlite库:
#import "sqlite3.h"
5、最后一步,在项目配置界面,选择build setting,搜索框中输入swift,在结果中选择objective-c bridging header,输入刚才新建的桥接文件的名称:
整个引入工作已经完成了,可以测试下是否引入成功,在swift文件中,输入sqlite3,看是否有sqlite3相关的智能提示出来。
创建(打开)与关闭数据库
要创建或者打开一个sqlite数据库,使用sqlite3_open方法,我们无需手动创建一个数据库文件,如果没有文件,sqlite3_open方法会为我们自动创建数据库文件,然后打开数据库。
//数据库存放路径 let sqlitepath = nshomedirectory().stringbyappendingpathcomponent("documents/sqlite3.db") //打开数据库,指定数据库文件路径,如果文件不存在后先创建文件,再打开,所以无需手动创建文件 let state = sqlite3_open(sqlitepath, &db) if state == sqlite_ok{ println("打开数据库成功") }else{ println("打开数据库失败") }
这里sqlite3_open方法的第二个参数是一个指针,是数据库打开后返回的一个操作指针,通过使用它,我们可以对数据库进行一系列的操作。我们先把它定义在外面,方便我们使用。
var db:copaquepointer = nil override func viewdidload() { super.viewdidload() ... }
创建表和删除表
使用sqlite3_exec方法可以执行一段sql语句,主要就是sql语句的差异,其他都一样:
//创建表 let createtable = "create table if not exists students (id integer primary key autoincrement,name text,stuid integer)" let result = sqlite3_exec(db, createtable, nil, nil, nil) if result == sqlite_ok{ println("创建表成功") } //删除表 let removetable = "drop table studets" let result2 = sqlite3_exec(db, removetable, nil, nil, nil) if result2 == sqlite_ok{ println("删除表成功") }
插入更新删除数据
插入数据使用了占位符,sql语句中使用问号代表值。使用sqlite3_bind_xxx来绑定值。
//插入数据 let inserttable = "insert into studets (stuid,name) values(?,?)" var statement:copaquepointer = nil let result3 = sqlite3_prepare_v2(db, inserttable, -1, &statement, nil) if result3 == sqlite_ok{ //绑定数据 sqlite3_bind_int(statement, 1, 1) sqlite3_bind_text(statement, 2, "lijialong", -1, nil) //执行 if sqlite3_step(statement) == sqlite_done{ println("数据插入成功") } sqlite3_finalize(statement) }
更新数据也类似几个步骤:
let updatetable = "update studets set name ='ss' where id = 1" var statement:copaquepointer = nil sqlite3_prepare_v2(db, updatetable, -1, &statement, nil) sqlite3_step(statement) sqlite3_finalize(statement)
删除数据:
let deleterow = "delete from studets where name='lijialong'" sqlite3_prepare_v2(db, deleterow, -1, &statement, nil) sqlite3_step(statement) sqlite3_finalize(statement)
查询数据
//查询数据 let query = "select * from studets" //这条执行后,数据就已经在sattement中了 sqlite3_prepare_v2(db, query, -1, &statement, nil) //游标往下走一步,如果返回sqlite_row就进入 while sqlite3_step(statement) == sqlite_row{ let id = sqlite3_column_int(statement, 0) let stuid = sqlite3_column_int(statement, 2) }
以上就是关于ios中sqlite数据库的原生用法详细介绍,希望对大家的学习有所帮助。
推荐阅读
-
iOS中的NSURLCache数据缓存类用法解析
-
iOS中管理剪切板的UIPasteboard粘贴板类用法详解
-
iOS中的UISlider滑块组件用法总结
-
iOS App使用SQLite之句柄的定义及数据库的基本操作
-
iOS App项目中引入SQLite数据库的教程
-
iOS App开发中的UISegmentedControl分段组件用法总结
-
iOS中的UIStepper数值加减器用法指南
-
iOS中UIActivityIndicatorView的用法及齿轮等待动画实例
-
iOS中UIImagePickerController图片选取器的用法小结
-
详解iOS App中UiTabBarController组件的基本用法