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的更多相关文章

  1. iOS开发——数据持久化Swift篇&使用Core Data进行数据持久化存储

    使用Core Data进行数据持久化存储   一,Core Data介绍 1,Core Data是iOS5之后才出现的一个数据持久化存储框架,它提供了对象-关系映射(ORM)的功能,即能够将对象转化成 ...

  2. iOS开发——数据持久化Swift篇&(二)沙盒文件

    沙盒文件 //******************** 5.2 文件操作 func use_FileOperations() { //1.获取程序的Home目录 let homeDirectory = ...

  3. iOS开发——数据持久化Swift篇&(一)NSUserDefault

    NSUserDefault //******************** 5.1 NSUserDefault和对象归档 func useNSUserDefault() { //通过单利来创建一个NSU ...

  4. iOS开发——数据持久化Swift篇&文件目录路径获取(Home目录,文档目录,缓存目录等)

    文件目录路径获取(Home目录,文档目录,缓存目录等)   iOS应用程序只能在自己的目录下进行文件的操作,不可以访问其他的存储空间,此区域被称为沙盒.下面介绍常用的程序文件夹目录:   1,Home ...

  5. iOS开发——数据持久化Swift篇&iCloud云存储

    iCloud云存储 import UIKit class ViewController: UIViewController { override func viewDidLoad() { super. ...

  6. iOS开发——数据持久化Swift篇&SettingBundle

    SettingBundle import UIKit class ViewController: UIViewController { var userDefault = NSUserDefaults ...

  7. iOS开发——数据持久化Swift篇&(四)CoreData

    CoreData import CoreData class ViewController: UIViewController { override func viewDidLoad() { supe ...

  8. iOS开发——数据持久化Swift篇&通用文件存储

    通用文件存储 import UIKit class ViewController: UIViewController { @IBOutlet weak var textField: UITextFie ...

  9. iOS开发——数据持久化Swift篇&模型对象归档

    模型对象归档 import UIKit class ViewController: UIViewController { @IBOutlet weak var textField: UITextFie ...

随机推荐

  1. Ansible的条件语句

    此篇主要讲述的ansible的condition,主要是用条件进行一些判断,此篇为官方文档的翻译,没有进行相关的测试,后续会写入相关的测试. Ansible的条件语句 1.    前言 在有的时候pl ...

  2. 【LeetCode】96 - Unique Binary Search Trees

    Given n, how many structurally unique BST's (binary search trees) that store values 1...n? For examp ...

  3. motan源码解读:注册中心zookeeper(2)

    上文大概讲解了利用zookeeper如何实现注册中心的.本文主要是从源码角度说明下.代码都在模块motan-registry-zookeeper中,其实在在这个模块中就3个类. ZkNodeType: ...

  4. Scrum角色

    产品负责人(Product Owner)的职责如下: 确定产品的功能. 决定发布的日期和发布内容. 为产品的profitability       of the product (ROI)负责. 根据 ...

  5. MapSearch 阅读随笔

    MapSearch https://developer.apple.com/library/ios/samplecode/MapSearch/Introduction/Intro.html#//app ...

  6. [cocos2d-js]按钮整合成大图后打APK后不显示

    网页版本都能正常显示碎图和整合成大图的 手机版本不正常 var btnKick = cc.MenuItemImage.create( "#btn_kick.png", " ...

  7. 第三百三十八天 how can I 坚持

    下午去奥体森林公园跑了个步,好累. 晚上和徐斌同学一起吃了个饭,接触了下杨辉三角,还没整明白,明天看下. 突然想起java 编译,ant脚本. 要精通门技术,还要赶上潮流. 睡觉.

  8. 异常处理与MiniDump详解(转)

    一.   综述 总算讲到MiniDump了. Dump有多有用我都无法尽数,基本上属于定位错误修复BUG的倚天剑.(日志可以算是屠龙刀)这些都是对于那些不是必出的BUG,放在外面运行的时候出现的BUG ...

  9. USB枚举过程(1)

    总的过程 ① host检测到device,reset 获取设备描述符 host发获取设备描述符请求 ->setup ->data0 <-ack Divice 返回设备描述符 -> ...

  10. .java 文件中只能定义一个public class 且与文件名相同