SQLite数据操作
1.向学生表中插入100条数据
2.按条件查询学生数据
3.修改学生数据
4.删除学生数据
import UIKit
class ViewController: UIViewController {
lazy var documentsPath:String={
let paths=NSSearchPathForDirectoriesInDomains(.DocumentDirectory,.UserDomainMask,true)
return paths.first!
}()
var db:COpaquePointer=nil
var stmt:COpaquePointer=nil
override func viewDidLoad() {
super.viewDidLoad()
createOrOpenDatabase()
//createTable()
//基本步骤
//1.打开数据库
//2.处理数据
//3.关闭数据库
//插入数据
//insertStudents()
//查询数据
//queryStudents()
//修改学生数据
//updateStudent()
//queryStudents()
//删除学生数据
deleteStudents()
queryStudents()
//关闭数据库
sqlite3_close(db)
}
}
extension ViewController{
func createOrOpenDatabase(){
print("\(NSHomeDirectory())")
let path:NSString = "\(documentsPath)/test.sqlite3"
let filename=path.UTF8String
if sqlite3_open(filename,&db) != SQLITE_OK {
print("create or open failed.......")
sqlite3_close(db)
}
}
func createTable(){
let string:NSString = "create table if not exists Student(id integer primary key autoincrement,sno text,name text,score,integer)"
let sql = string.UTF8String
if sqlite3_exec(db,sql,nil,nil,nil) != SQLITE_OK{
print("create table failed......")
sqlite3_close(db)
}
}
func insertStudents(){
//sno: "1001~1100"
//name: "[a-j][01-10]"
//score: 0-100
let strs1=["a","b","c","d","e","f","g","h","i","j"]
let strs2=["01","02","03","04","05","06","07","08","09","10"]
for i in 0..<100{
let sno="\(1001+i)"
let name=strs1[i/10] + strs2[i%10]
let score=i
insertStudent(sno:sno,name:name,score:score)
}
}
func insertStudent(sno sno:String,name:String,score:Int){
//准备SQL语句
let string:NSString="insert into Student(sno,name,score) values(?,?,?)"
let sql=string.UTF8String
//解析SQL文本语句
if sqlite3_prepare_v2(db,sql,-1,&stmt,nil) != SQLITE_OK{
sqlite3_close(db)
print("\(sno),insert failed......")
}
//绑定参数
let csno=(sno as NSString).UTF8String
let cname=(name as NSString).UTF8String
sqlite3_bind_text(stmt,1,csno,-1,nil)
sqlite3_bind_text(stmt,2,cname,-1,nil)
sqlite3_bind_int(stmt,3,Int32(score))
//执行SQL语句
if sqlite3_step(stmt) == SQLITE_ERROR{
sqlite3_close(db)
print("\(sno),insert failed......")
}else{
//释放资源
sqlite3_finalize(stmt)
}
}
func queryStudents(){
//准备SQL语句
let string:NSString="select sno,name,score from Student"
//let string:NSString="select sno,name,score from Student where score > 60"
//let string:NSString="select sno,name,score from Student where name like 'a%'"
let sql=string.UTF8String
//解析SQL文本语句
if sqlite3_prepare_v2(db,sql,-1,&stmt,nil) != SQLITE_OK{
sqlite3_close(db)
print("query failed......")
return
}
//执行SQL语句
while sqlite3_step(stmt) == SQLITE_ROW{
let csno = sqlite3_column_text(stmt,0)
let sno = NSString(UTF8String:UnsafePointer(csno))!
let cname = sqlite3_column_text(stmt,1)
let name=NSString(UTF8String:UnsafePointer(cname))!
let score=sqlite3_column_int(stmt,2)
print("\(sno),\(name),\(score)")
}
//释放资源
sqlite3_finalize(stmt)
}
func updateStudent(){
let string:NSString = "update Student set score = 100 where name like 'a%'"
let sql = string.UTF8String
if sqlite3_exec(db,sql,nil,nil,nil) != SQLITE_OK{
sqlite3_close(db)
print("update failed......")
}
}
func deleteStudents(){
let string:NSString="delete from Student where score <60"
let sql = string.UTF8String
if sqlite3_exec(db,sql,nil,nil,nil) != SQLITE_OK {
sqlite3_close(db)
print("delete failed......")
}
}
}
SQLite数据操作的更多相关文章
- [Sqlite]-->Java采用jdbc联系Sqlite各种特定的工艺数据库的数据操作
引: 1, Sqlite在Windows.Linux 和 Mac OS X 上的安装过程 2.嵌入式数据库的安装.建库.建表.更新表结构以及数据导入导出等等具体过程记录 3,嵌 ...
- mono for android中使用dapper或petapoco对sqlite进行数据操作
在mono for android中使用dapper或petapoco,很简单,新建android 类库项目,直接把原来的文件复制过来,对Connection连接报错部分进行注释和修改就可以运行了.( ...
- UWP开发之ORM实践:如何使用Entity Framework Core做SQLite数据持久层?
选择SQLite的理由 在做UWP开发的时候我们首选的本地数据库一般都是Sqlite,我以前也不知道为啥?后来仔细研究了一下也是有原因的: 1,微软做的UWP应用大部分也是用Sqlite.或者说是微软 ...
- Unity3D连接sqlite数据库操作C#版
unity3d有自己对应的sqlite.dll分别需要三个文件 1.Mono.Data.Sqlite.dll 在unity安装文件“Unity\Editor\Data\MonoBleedingEdge ...
- 我的Android六章:Android中SQLite数据库操作
今天学习的内容是Android中的SQLite数据库操作,在讲解这个内容之前小编在前面有一篇博客也是讲解了SQLite数据库的操作,而那篇博客的讲解是讲述了 如何在Window中通过DOM来操作数据库 ...
- (转)SQLLite数据操作
原文:http://dreamboy.blog.51cto.com/3180937/722352 SQLLite数据操作 一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存 ...
- 安卓 SQLite数据库操作实例
前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...
- 在安卓开发中使用SQLite数据库操作实例
前段时间写了个安卓平台下SQLite数据库操作的实例 ,一直没得时间总结 ,今天把它弄出来了. 在Android 运行时环境包含了完整的 SQLite. 首先介绍一下SQLite这个数据库: SQLi ...
- SQLite CRUD操作
SQLite CRUD操作代码实例: 1:首先创建一个继承了SQLiteOpenHelper类的MyDatabaseHelper类.实现他的onCreate(SQLiteDatabase db) on ...
随机推荐
- MySQL如何查询两个日期之间的记录
baidu出来的结果多是下面答案:<quote> MySQL中,如何查询两个日期之间的记录,日期所在字段的类型为datetime(0000-00-00 00:00:00) 解决方案: 直接 ...
- UnityShader快速上手指南(三)
简介 这一篇还是一些基本的shader操作:裁剪.透明和法向量的应用 (纠结了很久写不写这些,因为代码很简单,主要是些概念上的东西) 先来看下大概的效果图:(从左到右依次是裁剪,透明,加了法向量的透明 ...
- Winform开发框架之客户关系管理系统(CRM)的开发总结系列2-基于框架的开发过程
在上篇随笔<Winform开发框架之客户关系管理系统(CRM)的开发总结系列1-界面功能展示>中介绍了我的整个CRM系统的概貌,本篇继续本系列的文章,介绍如何基于我的<winform ...
- EffectiveJava——用函数对象表示策略
有些语言支持函数指针.代理.lambda表达式,或者支持类似的机制,允许程序把“调用特殊函数的能力”储存起来并传递这种能力.这种机制通常用于允许函数的调用者通过传入第二个函数,来指定自己的行为.比较器 ...
- mac下eclipse的svn(即svn插件)怎么切换账号?
以mac os x为例(Unix/Linux类似) 打开命令行窗口,即用户的根目录(用户的home目录) cd ~ 即可进入home目录. 执行命令 ls -al 会列出home目录下的所有文件及文件 ...
- 可怜的js居然没有块级作用域
js中在一个函数中定义一个for循环:for(var i=0;i<5;i++) 其中的i并不会随着for循环的结束就销毁,i会一直存在该函数中,这就是js和其他语言的区别,也就是js没有块级作用 ...
- 约瑟夫问题(c++实现)
描述:约瑟夫问题:有n只猴子,按顺时针方向围成一圈选大王(编号从1到n),从第1号开始报数,一直数到m,数到m的猴子退出圈外,剩下的猴子再接着从1 开始报数.就这样,直到圈内只剩下一只猴子时,这个猴子 ...
- ADODB.Connection 错误 ‘800a0e7a’ 未找到提供程序
问题表现:做网站ASP页面提示:ADODB.Connection 错误 '800a0e7a' 未找到提供程序.该程序可能未正确安装. 解决方案:一般都是64位系统的原因,把IIS切换为32Bit模式运 ...
- SAP中的Currency Converting Factor
ABAP编程中,有个概念很重要,即Currency Converting Factor(货币转换因子).可能很多ABAP初学者都不知道这是什么东西,这里我们就简单探讨下. 1. 什么是货币转换因子 在 ...
- andriod VideoView
package com.example.yanlei.myyk; import android.media.MediaPlayer; import android.net.Uri; import an ...