当前位置: 首页 > news >正文

ios swift sqlite3 简单使用

一.创建Person类

import UIKitclass Person: NSObject {var name:String? = nilvar sex:String? = nilvar age:String? = niloverride func setValue(_ value: Any?, forUndefinedKey key: String) {}}

二.在使用的地方导入sqlite.3头文件,例如方法都在viewcontroller中使用

import UIKit
import SQLite3

三.viewcontroller数据sqlite的增,删,查,等方法

    //打开数据库表func opneDB() -> Bool {let docDir:String! = NSSearchPathForDirectoriesInDomains(FileManager.SearchPathDirectory.documentDirectory, FileManager.SearchPathDomainMask.userDomainMask, true).firstlet fileName:String! = docDir + "/demo1.sqlite"if sqlite3_open(fileName, &db) != SQLITE_OK {print("打开数据库失败")return false} else {print("打开数据库成功")return true}}//创建数据库表func creatTable() ->Bool {let sql = "CREATE TABLE persontable(id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,name TEXT NOT NULL, age TEXT NOT NULL,sex TEXT NOT NULL);"// 第1个参数是 数据库db 第2个是要执行的sql 第3,4个是回调  第5个是错误信息let result = sqlite3_exec(db, sql, nil, nil, nil)return result == SQLITE_OK}// 插入数据func insert(nameText:String, ageText:String, sexText:String) -> Bool{let sql = "insert into persontable(name,age,sex) VALUES(?,?,?);"var stmt: OpaquePointer?let prepareResult = sqlite3_prepare_v2(db, sql, -1, &stmt, nil)if prepareResult != SQLITE_OK {sqlite3_finalize(stmt)if let msg = sqlite3_errmsg(db) {print("insert prepare 发生错误: \(msg)")}return false}let name = (nameText as NSString).utf8Stringlet age = (ageText as NSString).utf8Stringlet sex = (sexText as NSString).utf8Stringsqlite3_bind_text(stmt, 1, name, -1, nil)sqlite3_bind_text(stmt, 2, age, -1, nil)sqlite3_bind_text(stmt, 3, sex, -1, nil)let stepResult = sqlite3_step(stmt)if stepResult != SQLITE_OK && stepResult != SQLITE_DONE {sqlite3_finalize(stmt)if let msg = sqlite3_errmsg(db) {print("insert step 发生错误: \(msg)")}return false}sqlite3_finalize(stmt)return true}// 查询数据func queryAll()-> [Any]? {var persons = [Person]()//根据查询条件查询数据//let namestr:String = "张三"//let sql = "SELECT * FROM persontable WHERE  name LIKE '%\(namestr)%';"let sql = "SELECT * FROM persontable ;"var stmt: OpaquePointer?// 编译let prepareResult = sqlite3_prepare_v2(db, sql, -1, &stmt, nil)if prepareResult != SQLITE_OK {// 关闭语句句柄sqlite3_finalize(stmt)if let msg = sqlite3_errmsg(db) {print("insert prepare 发生错误: \(msg)")}return []}while sqlite3_step(stmt) == SQLITE_ROW {let person = Person()//let index = String.init(cString: sqlite3_column_text(stmt, 0)!)let name = String.init(cString: sqlite3_column_text(stmt, 1)!)let age = String.init(cString: sqlite3_column_text(stmt, 2)!)let sex = String.init(cString: sqlite3_column_text(stmt, 3)!)print("查询数据----\(name)--\(age)--\(sex)")person.name = nameperson.age = ageperson.sex = sexpersons.append(person)}sqlite3_finalize(stmt)print("查询数据库成功")return persons}//更新列表func update(name: String, toName: String) -> Bool {//根据条件删除let sql = "update persontable set tradename = '\(toName)' where tradename = '\(name)'";return self.exec(sql: sql)}// 删除数据func delete(name: String) -> Bool{//删除sql语句//let sql = "delete from qingmeitable where tradename = '\(name)'"let sql = "delete from persontable "return self.exec(sql: sql)}// 执行编译sqlprivate func exec(sql: String) -> Bool{// sqlite3_stmt指针var stmt: OpaquePointer?// 编译let prepareResult = sqlite3_prepare_v2(self.db, sql, -1, &stmt, nil)if prepareResult != SQLITE_OK {// 关闭语句句柄sqlite3_finalize(stmt)if let msg = sqlite3_errmsg(db) {print("delete prepare 发生错误: \(msg)")}return false}let stepResult = sqlite3_step(stmt)if stepResult != SQLITE_OK && stepResult != SQLITE_DONE {sqlite3_finalize(stmt)if let msg = sqlite3_errmsg(db) {print("delete step 发生错误: \(msg)")}return false}sqlite3_finalize(stmt)return true}

参考链接

http://www.lryc.cn/news/233068.html

相关文章:

  • 长古诗(一)
  • VC++ 预编译头学习
  • JVM内存模型:理解Java程序的内存管理
  • golang opt-in transparent telemetry
  • 数据资产“入表”是不是红利?国企怎么认识?怎么利用?
  • 薪资面谈小技巧
  • 基于Java的鲜花商店的设计与实现,ssm+jsp,MySQL数据库,前台用户+后台管理,完美运行,有一万字论文
  • vue3 父组件调用子组件的方法
  • 和鲸科技创始人范向伟受邀出席“凌云出海,来中东吧”2023华为云上海路演活动
  • 短路语法 [SUCTF 2019]EasySQL1
  • 鉴源实验室 | DoIP协议网络安全攻击
  • 腾讯云服务器新用户购买优惠多少钱?腾讯云新用户购买优惠
  • 超全整理,Pytest自动化测试框架-多进程(pytest-xdist)运行总结...
  • jbase实现通用码表
  • 工业镜头中的远心镜头与普通镜头的光路
  • 【Qt之QWizardPage】使用
  • 自动化测试,5个技巧轻松搞定
  • EasyWeChat调用企业微信接口获取客户群数据
  • sql 左联 右联
  • k8s中的端口hostPort、port、nodePort、targetPort
  • 自动发微博脚本工具,可批量定时发送,按键精灵完全开源版
  • 2023版Idea创建JavaWeb时,右键new没有Servlet快捷键选项
  • 数据结构(c语言版本) 二叉树的遍历
  • Django 配置 Email Admin 详细指南
  • Apache阿帕奇安装配置
  • 时间序列预测实战(十六)PyTorch实现GRU-FCN模型长期预测并可视化结果
  • 如何提升软件测试效率?本文为你揭示秘密
  • 参数估计和非参数估计
  • Apache Airflow (八) :DAG任务依赖设置
  • 使用 com.jacob.activeX 库实现 Word 到 PDF