iOS中 DataBase SQL数据库 UI_高级
Student.h @interface Student : NSObject @property(nonatomic,assign)NSInteger number; @property(nonatomic,copy)NSString *name; @property(nonatomic,copy)NSString *gender; @property(nonatomic,assign)NSInteger age; @end Student.m @implementation Student - (void)dealloc{ self.name = nil; self.gender = nil; [super dealloc]; } - (NSString *)description { return [NSString stringWithFormat:@"%ld %@ %@ %ld", self.number,self.name,self.gender,self.age]; } @end
通过单例写接口并实现方法:
DataBaseHandle.h @class Student; @interface DataBaseHandle : NSObject //创建单例的方法 + (DataBaseHandle *)shareDataBaseHandle; //打开数据库的方法 - (void)openDataBase; //关闭数据库的方法 - (void)closeDataBase; //插入学生对象的接口 - (void)insertStudent : (Student *)student; //返回表格中所有学生的接口 - (NSMutableArray *)selectAllStudent; //根据唯一标识学号删除学生 - (void)deleteOneStudentByNumber : (NSInteger )number; //根据唯一标识学号修改学生的姓名 - (void)updateStudentGender : (NSString *)gender ByNumber : (NSInteger )number; //根据学号查找学生 - (Student *)selectOneStudentByNumber : (NSInteger)number; @end
DataBaseHandle.m
#import "DataBaseHandle.h" #import <sqlite3.h> #import "Student.h" @implementation DataBaseHandle static DataBaseHandle *handle = nil; //创建单例的方法 + (DataBaseHandle *)shareDataBaseHandle{ @synchronized(self){ if (handle == nil) { handle = [[DataBaseHandle alloc]init]; //让单例对象一创建后就可以访问数据库 [handle openDataBase]; } } return handle; } //返回数据库路径 - (NSString *)dataBasePath{ //将数据库文件放到Documents文件夹下 student.sqlite return [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]stringByAppendingPathComponent:@"student.sqlite"]; }
定义一个全局且在静态区的数据库指针
static sqlite3 *db = nil;
打开数据库的方法
- (void)openDataBase{ //1.先获取数据文件的路径 NSString *dbPath = [self dataBasePath]; //使用sql之前一定要导入libsqlite3.0动态链接类库,其中libsqlite.3.0是快捷方式,导入快捷方式的好处,当版本更新的时候,不再导入新的实体类库了,因为快捷方式永远指向的是最新的实体类库(记得导入头文件) //2.使用sql语句打开数据库
//[dbPath UTF8String] 将OC字符串转化为C语言字符串 //sqlite3 就是数据库指针 //创建数据库指针db // sqlite3 *db = nil; //方法执行完,内不会对数据库指针db进行初始化,方法执行完,就会存在数据库文件 //此方法会先检测文件路径中有没有对应的数据库文件,没有则创建,有的话直接打开 int result = sqlite3_open([dbPath UTF8String], &db); //SQLITE_OK 说明sql是成功 if (result == SQLITE_OK) { // NSLog(@"数据库打开成功"); //创建表格 //准备sql语句 NSString *sqlString = @"create table if not exists Student(stu_number integer primary key autoincrement,stu_name text,stu_gender text,stu_age integer)"; //执行sql语句 sqlite3_exec(db, [sqlString UTF8String], NULL, NULL, NULL); }else{ NSLog(@"数据库打开失败"); } }
关闭数据库的方法
- (void)closeDataBase{ int result = sqlite3_close(db); NSLog(@"%@",(result == SQLITE_OK) ? @"关闭成功":@"关闭失败"); }
插入学生对象的接口——增
- (void)insertStudent : (Student *)student{ //1.打开数据库 [self openDataBase]; //2.准备插入的sql语句 NSString *sqlString = @"insert into Student(stu_name,stu_gender,stu_age)values(?,?,?)"; //3.创建数据库管理指针(数据库管理指令集) sqlite3_stmt *stmt = nil; //4.验证sql语句是否正确 //参数1:数据库指针, //参数2:sql语句 //参数3:sql语句的长度写成-1,自动计算sql语句的最大长度,否则要自己计算长度 //参数4:sql语句的管理指针 //参数5:预留参数,未来使用 //5.拿验证的结果,判断是否执行参数绑定的操作 int result = sqlite3_prepare_v2(db, [sqlString UTF8String], -1, &stmt, NULL); if (result == SQLITE_OK) { NSLog(@"插入成功"); //参数1:sql语句管理指针 //参数2:上面sql语句中 ?的位置,?的下标从1开始 //参数3:要绑定的数据 //参数4:数据的长度 //绑定字段stu_name 的数据 sqlite3_bind_text(stmt, 1, [student.name UTF8String], -1, NULL); //绑定字段stu_gender 的数据 sqlite3_bind_text(stmt, 2, [student.gender UTF8String], -1, NULL); //绑定字段stu_age 的数据 sqlite3_bind_int(stmt, 3, (int)student.age); //6.让sql语句执行 sqlite3_step(stmt); } //7.释放掉管理指针 sqlite3_finalize(stmt); //8.关闭数据库 [self closeDataBase]; }
返回表格中所有学生的接口——查1
- (NSMutableArray *)selectAllStudent{ //1.打开数据库 [self openDataBase]; //2.准备sql语句 NSString *sqlString = @"select * from Student"; //3.创建管家指针 sqlite3_stmt *stmt = nil; //4.验证sql语句是否正确 int result = sqlite3_prepare_v2(db, [sqlString UTF8String], -1, &stmt, NULL); if (SQLITE_OK == result) { NSLog(@"查找全部语句成功"); //创建可变数组存储找到所有的学生对象 NSMutableArray *array = [NSMutableArray arrayWithCapacity:0]; //SQLITE_ROW 如果等于row说明下一行是有数据的,循环继续,如果不等于SQLITE_ROW ,说明下一行没有数据了,循环结束 while (sqlite3_step(stmt) == SQLITE_ROW) { //依次读出字段的数据 //列的编号是从零开始的 //第一列 int number = sqlite3_column_int(stmt, 0); //第二列 NSString *name = [NSString stringWithUTF8String:(const char *) sqlite3_column_text(stmt, 1) ]; //第三列 NSString *gender = [NSString stringWithUTF8String:(const char *)sqlite3_column_text(stmt, 2)]; //第四列 int age = sqlite3_column_int(stmt, 3); //5.创建学生对象并赋值 Student *stu = [[Student alloc]init]; stu.number = number; stu.name = name; stu.gender = gender; stu.age = age; //添加到数组 [array addObject:stu]; //释放 [stu release]; } //6.释放管理指针 sqlite3_finalize(stmt); //关闭数据库 [self closeDataBase]; return array; }else{ sqlite3_finalize(stmt); [self closeDataBase]; return nil; } }
根据学号查找学生——查2
- (Student *)selectOneStudentByNumber : (NSInteger)number{ //1.打开数据库 [self openDataBase]; //2.准备sql语句 NSString *sqlString = @"select * from Student where stu_number = ?"; //3.创建管理指针 sqlite3_stmt *stmt = nil; //4.验证sql语句是否正确 int result = sqlite3_prepare_v2(db, [sqlString UTF8String], -1, &stmt, NULL); //5.根据验证结果决定执行什么操作 if (result == SQLITE_OK) { //6.绑定参数 sqlite3_bind_int(stmt, 1, (int)number); //7.遍历表格中的数据 //创建model学生对象存储找到的学生信息 Student *stu = [[Student alloc]init]; while (sqlite3_step(stmt) == SQLITE_ROW) { //根据找到的数据给学生的属性赋值 stu.number = number; stu.name =[NSString stringWithUTF8String:(const char *) sqlite3_column_text(stmt, 1)]; stu.gender = [NSString stringWithUTF8String:(const char *)sqlite3_column_text(stmt, 2)]; stu.age = sqlite3_column_int(stmt, 3); } //8.释放管理指针 sqlite3_finalize(stmt); //9.关闭数据库 [self closeDataBase]; return [stu autorelease]; }else{ //10.释放管理指针 sqlite3_finalize(stmt); //11.关闭数据库 [self closeDataBase]; } return nil; }
根据唯一标识学号删除学生——删
- (void)deleteOneStudentByNumber : (NSInteger )number{ //1.打开数据库 [self openDataBase]; //2.准备删除sql语句 NSString *sqlString = @"delete from Student where stu_number = ?"; //3.创建数据库管理指针 sqlite3_stmt *stmt = nil; //4.验证sql语句是否正确 int result = sqlite3_prepare_v2(db, [sqlString UTF8String], -1, &stmt, NULL); //5.判断是否执行参数绑定的操作 if (result == SQLITE_OK) { //6.绑定传过来的参数 sqlite3_bind_int(stmt, 1, (int)number); //7.执行sql语句 sqlite3_step(stmt); } //8.释放掉管理指针 sqlite3_finalize(stmt); //9.关闭数据库 [self closeDataBase]; }
根据唯一标识学号修改学生的姓名——改
- (void)updateStudentGender : (NSString *)gender ByNumber : (NSInteger )number{ //1.打开数据库 [self openDataBase]; //2.准备sql语句 NSString *sqlString = @"update Student set stu_gender = ? where stu_number = ?"; //3.创建数据库管理指针 sqlite3_stmt *stmt = nil; //4.验证sql语句 int result = sqlite3_prepare_v2(db, [sqlString UTF8String], -1, &stmt, NULL); //5.根据验证的结果决定执行的操作 if (result == SQLITE_OK) { //6.绑定参数 sqlite3_bind_text(stmt, 1, [gender UTF8String], -1, NULL); //7.绑定学号 //第二个参数:是 ? 在sql语句中位置,位置从1开始 sqlite3_bind_int(stmt, 2, (int)number); //8.执行sql语句 sqlite3_step(stmt); } //9.释放管理指针 sqlite3_finalize(stmt); //10.关闭数据库 [self closeDataBase]; }
方法的调用:
ViewController.m
#import "ViewController.h" #import "DataBaseHandle.h" #import "Student.h" @interface ViewController () @property (retain, nonatomic) IBOutlet UITextField *numberField;//学号 @property (retain, nonatomic) IBOutlet UITextField *nameField;//姓名 @property (retain, nonatomic) IBOutlet UITextField *genderField;//性别 @property (retain, nonatomic) IBOutlet UITextField *ageField;//年龄 @end
1、添加:增
- (IBAction)insertStudent:(UIButton *)sender { //判断有一个控件中输入的内容为空,就不让它插入数据 if (0 == self.nameField.text.length || 0 == self.genderField.text.length || 0 == self.ageField.text.length) { return; } //创建学生Student 对象,存储空间中输入的内容 Student *stu = [[Student alloc]init]; stu.name = self.nameField.text; stu.gender = self.genderField.text; stu.age = [self.ageField.text integerValue]; [[DataBaseHandle shareDataBaseHandle]insertStudent:stu]; [stu release]; }
2、更新学生信息:改
- (IBAction)updateStudent:(UIButton *)sender { //获取输入框的内容 NSInteger number = [self.numberField.text integerValue]; NSString *gender = self.genderField.text; //调用根据学号修改gender的方法 [[DataBaseHandle shareDataBaseHandle]updateStudentGender:gender ByNumber:number]; }
3、删除学生:删
- (IBAction)deleteStudent:(UIButton *)sender { NSInteger number = [self.numberField.text integerValue]; //调用根据学号删除学生的方法 [[DataBaseHandle shareDataBaseHandle]deleteOneStudentByNumber:number]; }
4、查找全部学生:查1
- (IBAction)selectAllStudent:(UIButton *)sender { //调用寻找所有学生 NSMutableArray *contentArray = [[DataBaseHandle shareDataBaseHandle]selectAllStudent]; for (Student *stu in contentArray) { NSLog(@"%@",stu); } }
5、查找某个学生:查2
- (IBAction)selectOneStudent:(id)sender { //获取学号输入框的内容 NSInteger number = [self.numberField.text integerValue]; //调用根据学号获取学生对象 Student *stu = [[DataBaseHandle shareDataBaseHandle]selectOneStudentByNumber:number]; NSLog(@"%@",stu); }
记得释放:
- (void)dealloc { [_numberField release]; [_nameField release]; [_genderField release]; [_ageField release]; [super dealloc]; }
总结:一般步骤:1、打开数据库;2、准备sql语句;3、创建管家指针;4、验证sql语句是否正确;5、根据验证结果决定执行什么操作;6、绑定参数;7、遍历表格中的数据(根据学号查找学生);8、释放管理指针;9、关闭数据库
iOS中 DataBase SQL数据库 UI_高级的更多相关文章
- iOS - SQLite Database 操作数据库
iOS - SQLite Database 操作数据库 Sqlite 能被用在ios上做数据处理用,只要你懂得一点sql 就很容易使用sqlite 1:创建一个简单的View based appl ...
- IOS中使用轻量级数据库
IOS中使用轻量级数据库 目录 概述 IOS中的轻量级数据库 sqlite的方法 数据库的实用操作 第三方类库 FMDatabase 概述 IOS中的轻量级数据库 sqlite的方法 sqlite3 ...
- SQL数据库— <3>高级查询、常用函数 --摘录网络
SQL Server T-SQL高级查询 高级查询在数据库中用得是最频繁的,也是应用最广泛的. Ø 基本常用查询 --select select * from student; --all 查询所有 ...
- Unity中对SQL数据库的操作
在Unity中,我们有时候需要连接数据库来达到数据的读取与储存.而在.NET平台下,ADO.NET为我们提供了公开数据访问服务的类.客户端应用程序可以使用ADO.NET来连接到数据源,并查询,添加,删 ...
- 关于Golang中database/sql包的学习
go-sql-driver 请求一个连接的函数有好几种,执行完毕处理连接的方式稍有差别,大致如下: db.Ping() 调用完毕后会马上把连接返回给连接池. db.Exec() 调用完毕后会马上把连接 ...
- 李洪强iOS开发之-sql数据库的使用
一,创建工程 二: 导入头文件 三:导入 四: 数据库增删改查 //因为是结构体类型,所以用assign //1.创建数据库(保存路径) @property(nonatomic,assign)sqli ...
- Oracle配置OneMap中的sql数据库问题及解决方案
报错ORA-00900:无效SQL语句,点确定后报错:ORA--00942:表或视图不存在 分析:prompt在Oracle中是打印功能,如果要在PLsql中执行带有prompt的sql文件就会报上面 ...
- Golang中database/sql包
驱动 github.com/go-sql-driver/mysql 请求一个连接的函数有好几种,执行完毕处理连接的方式稍有差别,大致如下: db.Ping() 调用完毕后会马上把连接返回给连接池. d ...
- ASP.NET中操作SQL数据库
在WebConfig中配置数据库连接字符串,代码如下: <connectionStrings> <add name="ConnectionString&qu ...
随机推荐
- Jackson工具
Jackson Jackson包含一个core JAR,和两个依赖core JAR的JAR: jackson-core-2.2.3.jar(核心jar包,下载地址) jackson-annotatio ...
- tomcat7+jdk的keytool生成证书 配置https
目前只会使用jdk的keytool来生成证书.本文仅介绍这种方法. 1Windows下: 1.1 生成keystore文件及导出证书 打开控制台: 运行: %JAVA_HOME%\bin\keytoo ...
- Hibernate QBC 条件查询(Criteria Queries) and Demos
目录 创建一个Criteria 实例 限制结果集内容 结果集排序 关联 动态关联抓取 查询示例 投影Projections聚合aggregation和分组grouping 离线detached查询和子 ...
- ubuntu下安装 python 常用软件
1.用于科学计算的常用包: sudo apt-get install python-numpy python-scipy python-matplotlib ipython ipython-noteb ...
- js数组排序,支持正反排序以及多维度排序
工作中遇到js数组排序问题,数组中存储的都是对象,于是就百度了下,利用别人的代码进行修改,最终完成可以倒序.反序,可以进行多维度排序的功能源码如下: /** * js数组排序 支持数字和字符串 * @ ...
- map函数、filer函数、reduce函数的用法和区别
Map函数 map函数的用法如下: def add_one(x): return x+1 #使用普通函数 v1 = map(add_one,[1,2,3]) v1 = list(v1) print(v ...
- MongoDB 高级索引
考虑以下文档集合(users ): { "address": { "city": "Los Angeles", "state&qu ...
- Android源码解析——Toast
简介 Toast是一种向用户快速展示少量信息的视图.当它显示时,它会浮在整个应用层的上面,并且不会获取到焦点.它的设计思想是能够向用户展示些信息,但又能尽量不显得唐突.本篇我们来研读一下Toast的源 ...
- javaweb异常提示信息统一处理(使用springmvc,附源码)
一.前言 后台出现异常如何友好而又高效地回显到前端呢?直接将一堆的错误信息抛给用户界面,显然不合适. 先不考虑代码实现,我们希望是这样的: (1)如果是页面跳转的请求,出现异常了,我们希望跳转到一个异 ...
- 我的第一本著作:Spark技术内幕上市!
现在各大网站销售中! 京东:http://item.jd.com/11770787.html 当当:http://product.dangdang.com/23776595.html 亚马逊:http ...