iOS开发——数据持久化Swift篇&(三)SQLite3
SQLite3
使用
//******************** 5.3 SQLite3存储和读取数据 func use_SQLite3() { //声明一个Documents下的路径 var dbPath = NSHomeDirectory() + "/Documents/SwiftClassDB.sqlite" //判断数据库文件是否存在 if !NSFileManager.defaultManager().fileExistsAtPath(dbPath) { //获取安装包内数据库路径 var bundleDBPath:String? = NSBundle.mainBundle().pathForResource("SwiftClassDB", ofType: "sqlite") //将安装包内数据库拷贝到Documents目录下 NSFileManager.defaultManager().copyItemAtPath(bundleDBPath!, toPath: dbPath, error: nil) } //打开数据库 let dbOperation = DatabaseOperations(dbPath: dbPath) //添加一张表 dbOperation.createTable(); //插入一条信息, 通过Person对象来传值 let person:Person = Person(name: ) dbOperation.addUser(person) //查询 let personArray:[Person] = dbOperation.readAllUsers() println("共搜索到:\(personArray.count) 条数据" ) //更新 dbOperation.updateUser("刘明洋", toName: "刘蕙通") //删除 dbOperation.deleteUser("刘蕙通") //关闭数据库 dbOperation.colseDb() } //******************** 5.4 Core Data func use_CoreData() { //参见工程 LMYCoreData }
数据操作
class DatabaseOperations { //不透明指针,对应C语言里面的void *,这里指sqlite3指针 private var db:COpaquePointer = nil //初始化方法打开数据库 required init(dbPath:String) { println("db path:" + dbPath) //String类的路径,转换成cString let cpath = dbPath.cStringUsingEncoding(NSUTF8StringEncoding) //打开数据库 let error = sqlite3_open(cpath!, &db) //数据库打开失败处理 if error != SQLITE_OK { sqlite3_close(db) } } deinit{ self.colseDb() } //关闭数据库 func colseDb(){ sqlite3_close(db) } //代码创建表 func createTable() -> Bool{ //sql语句 var sql = "CREATE TABLE UserTable(id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, username TEXT NOT NULL, password TEXT NOT NULL, email TEXT, age INTEGER)" //执行sql语句 var execResult = sqlite3_exec(db, sql.cStringUsingEncoding(NSUTF8StringEncoding)!, nil, nil, nil); //判断是否执行成功 if (execResult != SQLITE_OK) { return false } return true } //插入一条信息 func addUser(user: Person) -> Bool { //sql语句 var sql = "INSERT INTO UserTable (username, password, email, age) VALUES (?, ?, ?, ?);"; //sql语句转换成cString类型 var cSql = sql.cStringUsingEncoding(NSUTF8StringEncoding) //sqlite3_stmt 指针 var stmt:COpaquePointer = nil //1.编译sql let prepare_result = sqlite3_prepare_v2(self.db, cSql!, -, &stmt, nil) //判断如果失败,获取失败信息 if prepare_result != SQLITE_OK { sqlite3_finalize(stmt) if let error = String.fromCString(sqlite3_errmsg(self.db)) { let msg = "SQLiteDB - failed to prepare SQL: \(sql), Error: \(error)" println(msg) self.alert(msg) } return false } let intTran = UnsafeMutablePointer<Int>(bitPattern: -) let tranPointer = COpaquePointer(intTran) let transient = CFunctionPointer<((UnsafeMutablePointer<()>) -> Void)>(tranPointer) //2.bind 绑定参数 //第2个参数:索引从1开始 //最后一个参数为函数指针 sqlite3_bind_text(stmt, , user.name!.cStringUsingEncoding(NSUTF8StringEncoding)!, -, transient); sqlite3_bind_text(stmt, , user.password!.cStringUsingEncoding(NSUTF8StringEncoding)!, -, transient); sqlite3_bind_text(stmt, , user.email!.cStringUsingEncoding(NSUTF8StringEncoding)!, -, transient); sqlite3_bind_int(stmt, , CInt(user.age!)); //3.step执行 var step_result = sqlite3_step(stmt) //判断执行结果,如果失败,获取失败信息 if step_result != SQLITE_OK && step_result != SQLITE_DONE { sqlite3_finalize(stmt) if let err = String.fromCString(sqlite3_errmsg(self.db)) { let msg = "SQLiteDB - failed to execute SQL: \(sql), Error: \(err)" println(msg) self.alert(msg) } return false } //4.finalize sqlite3_finalize(stmt); return true } //查询 func readAllUsers() -> [Person]{ //声明一个Person对象数组(查询的信息会添加到该数组) var usersArr = [Person]() //查询sql语句 var sql = "SELECT * FROM UserTable;"; //sqlite3_stmt 指针 var stmt:COpaquePointer = nil var cSql = sql.cStringUsingEncoding(NSUTF8StringEncoding) //1.编译sql let prepare_result = sqlite3_prepare_v2(self.db, cSql!, -, &stmt, nil) if prepare_result != SQLITE_OK { sqlite3_finalize(stmt) if let error = String.fromCString(sqlite3_errmsg(self.db)) { let msg = "SQLiteDB - failed to prepare SQL: \(sql), Error: \(error)" println(msg) self.alert(msg) } return usersArr } //2.step while (sqlite3_step(stmt) == SQLITE_ROW) { var user = Person() //循环 从数据库获取数据,添加到数组中 let cName = UnsafePointer<CChar>(sqlite3_column_text(stmt, )) let cPwd = UnsafePointer<CChar>(sqlite3_column_text(stmt, )) let cEmail = UnsafePointer<CChar>(sqlite3_column_text(stmt, )) let cAge = sqlite3_column_int(stmt, ) user.name = String.fromCString(cName) user.password = String.fromCString(cPwd) user.email = String.fromCString(cEmail) user.age = Int(cAge) usersArr += [user] } //3.finalize sqlite3_finalize(stmt); return usersArr } //更新一条信息 func updateUser(name: String , toName:String) -> Bool { //更新sql语句 var sql = "update UserTable set username = '\(toName)' where username = '\(name)'"; //sqlite3_stmt 指针 var stmt:COpaquePointer = nil var cSql = sql.cStringUsingEncoding(NSUTF8StringEncoding) //1.编译sql let prepare_result = sqlite3_prepare_v2(self.db, cSql!, -, &stmt, nil) //判断如果失败,获取失败信息 if prepare_result != SQLITE_OK { sqlite3_finalize(stmt) if let error = String.fromCString(sqlite3_errmsg(self.db)) { let msg = "SQLiteDB - failed to prepare SQL: \(sql), Error: \(error)" println(msg) self.alert(msg) } return false } //3.step执行 var step_result = sqlite3_step(stmt) //判断执行结果,如果失败,获取失败信息 if step_result != SQLITE_OK && step_result != SQLITE_DONE { sqlite3_finalize(stmt) if let err = String.fromCString(sqlite3_errmsg(self.db)) { let msg = "SQLiteDB - failed to execute SQL: \(sql), Error: \(err)" println(msg) self.alert(msg) } return false } //4.finalize sqlite3_finalize(stmt); return true } //删除一条信息 func deleteUser(username: String) -> Bool { //删除sql语句 var sql = "delete from UserTable where username = '\(username)'"; //sqlite3_stmt 指针 var stmt:COpaquePointer = nil var cSql = sql.cStringUsingEncoding(NSUTF8StringEncoding) //1.编译sql let prepare_result = sqlite3_prepare_v2(self.db, cSql!, -, &stmt, nil) //判断如果失败,获取失败信息 if prepare_result != SQLITE_OK { sqlite3_finalize(stmt) if let error = String.fromCString(sqlite3_errmsg(self.db)) { let msg = "SQLiteDB - failed to prepare SQL: \(sql), Error: \(error)" println(msg) self.alert(msg) } return false } //3.step执行 var step_result = sqlite3_step(stmt) //判断执行结果,如果失败,获取失败信息 if step_result != SQLITE_OK && step_result != SQLITE_DONE { sqlite3_finalize(stmt) if let err = String.fromCString(sqlite3_errmsg(self.db)) { let msg = "SQLiteDB - failed to execute SQL: \(sql), Error: \(err)" println(msg) self.alert(msg) } return false } //4.finalize sqlite3_finalize(stmt); return true } //定义一个报警器 func alert(msg:String) { dispatch_async(dispatch_get_main_queue()) { let alert = UIAlertView(title: "SQLiteDB", message:msg, delegate: nil, cancelButtonTitle: "OK") alert.show() } } }
iOS开发——数据持久化Swift篇&(三)SQLite3的更多相关文章
- iOS开发——数据持久化Swift篇&使用Core Data进行数据持久化存储
使用Core Data进行数据持久化存储 一,Core Data介绍 1,Core Data是iOS5之后才出现的一个数据持久化存储框架,它提供了对象-关系映射(ORM)的功能,即能够将对象转化成 ...
- iOS开发——数据持久化Swift篇&(二)沙盒文件
沙盒文件 //******************** 5.2 文件操作 func use_FileOperations() { //1.获取程序的Home目录 let homeDirectory = ...
- iOS开发——数据持久化Swift篇&(一)NSUserDefault
NSUserDefault //******************** 5.1 NSUserDefault和对象归档 func useNSUserDefault() { //通过单利来创建一个NSU ...
- iOS开发——数据持久化Swift篇&文件目录路径获取(Home目录,文档目录,缓存目录等)
文件目录路径获取(Home目录,文档目录,缓存目录等) iOS应用程序只能在自己的目录下进行文件的操作,不可以访问其他的存储空间,此区域被称为沙盒.下面介绍常用的程序文件夹目录: 1,Home ...
- iOS开发——数据持久化Swift篇&iCloud云存储
iCloud云存储 import UIKit class ViewController: UIViewController { override func viewDidLoad() { super. ...
- iOS开发——数据持久化Swift篇&SettingBundle
SettingBundle import UIKit class ViewController: UIViewController { var userDefault = NSUserDefaults ...
- iOS开发——数据持久化Swift篇&(四)CoreData
CoreData import CoreData class ViewController: UIViewController { override func viewDidLoad() { supe ...
- iOS开发——数据持久化Swift篇&通用文件存储
通用文件存储 import UIKit class ViewController: UIViewController { @IBOutlet weak var textField: UITextFie ...
- iOS开发——数据持久化Swift篇&模型对象归档
模型对象归档 import UIKit class ViewController: UIViewController { @IBOutlet weak var textField: UITextFie ...
随机推荐
- java开发eclipse常见问题(一)The superclass "javax.servlet.http.HttpServlet" was not found on the Java Build Path
最近刚开始用Eclipse开发,刚开始都是按教程一步一步的新建web工程也没出现什么问题. 今天选了一个新的workspace,建了个web工程发现最简单的jsp页面都报错:The superclas ...
- JavaScript基础知识整理(1)数组
第一:创建. 1,var arr= new Array(); //数组为空.长度为0. arr[0]="apple"; arr[1]="orange"; arr ...
- Hadoop2.2.0 自动切换HA环境搭建
自动切换的HA,比手动切换HA集群多了一个zookeeper集群 机器分配: zookeeper:hadoop4,hadoop5,hadoop6 namenode:hadoop4,hadoop5 da ...
- reentrant可重入函数
在多任务操作系统环境中,应用程序的各个任务是并发运行的,所以会经常出现多个任务“同时”调用同一个函数的情况.这里之所以在“同时” 这个词上使用了引号,是因为这个歌”同时“的含义与我们平时所说的同时不是 ...
- labview在线帮助网址
http://zone.ni.com/reference/zhs-XX/help/371361L-0118/ labview网络讲坛 网址 http://v.eepw.com.cn/video/com ...
- 咏南WEB开发框架
和咏南CS开发框架共享同一个咏南中间件.
- css div 垂直居中
参考:http://css-tricks.com/centering-in-the-unknown/ <style> .valign { font-size: 0px;/* clear s ...
- 【转】Android -- Looper.prepare()和Looper.loop()
Looper.prepare()和Looper.loop() 原文地址:http://blog.csdn.net/heng615975867/article/details/9194219 Andro ...
- JAVA核心技术--继承
1.继承:向上追溯,对同一批类的抽象,延续和扩展父类的一切信息! 1)关键字:extends 例如,父类是Animal,子类是Dog; eg: public class Dog exte ...
- mac 开发必备软件(不断update ing...)
整理下mac环境下, 开发必备的一些软件吧, 由于不断要更新ing, 用到啥就写啥~球轻拍 1.host 绑定切换神器 a.gas mask : 只能切换单个自定义的host文件 b.ihosts(推 ...