IOS学习笔记-- SQLite的应用

  1 //
  2 //  HMViewController.m
  3 //  02-SQLite的应用
  4 //
  5 //  Created by apple on 14-7-24.
  6 //  Copyright (c) 2014年 heima. All rights reserved.
  7 //
  8
  9 #import "HMViewController.h"
 10 #import <sqlite3.h>
 11
 12 @interface HMViewController ()
 13 - (IBAction)insert;
 14 - (IBAction)update;
 15 - (IBAction)delete;
 16 - (IBAction)select;
 17 // db就是数据库的象征,如果要进行CRUD,得操作db这个实例
 18 @property (nonatomic, assign) sqlite3 *db;
 19 @end
 20
 21 @implementation HMViewController
 22
 23 - (void)viewDidLoad
 24 {
 25     [super viewDidLoad];
 26
 27     // 获得数据库文件的路径
 28     NSString *doc = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
 29     NSString *filename = [doc stringByAppendingPathComponent:@"students.sqlite"];
 30     // 将OC字符串 转成 C语言字符串
 31     const char *cfilename = filename.UTF8String;
 32     // 1.打开数据库(如果数据库文件不存在,sqlite3_open函数会自动创建数据库文件)
 33     int result = sqlite3_open(cfilename, &_db);
 34     if (result == SQLITE_OK) { // 打开成功
 35         NSLog(@"成功打开数据库");
 36
 37         // 2.创表
 38         const char *sql = "CREATE TABLE IF NOT EXISTS t_student (id integer PRIMARY KEY AUTOINCREMENT, name text NOT NULL, age integer NOT NULL);";
 39         char *erroMsg = NULL;
 40         result = sqlite3_exec(self.db, sql, NULL, NULL, &erroMsg);
 41         if (result == SQLITE_OK) {
 42             NSLog(@"成功创表");
 43         } else {
 44             //            printf("创表失败--%s--%s-%d", erroMsg, __FILE__, __LINE__);
 45             NSLog(@"创表失败--%s--%@-%d", erroMsg, [NSString stringWithUTF8String:__FILE__], __LINE__);
 46         }
 47     } else {
 48         NSLog(@"打开数据库失败");
 49     }
 50 }
 51
 52 - (IBAction)insert {
 53     for (int i = 0; i<20; i++) {
 54         // 1.拼接SQL语句
 55         NSString *name = [NSString stringWithFormat:@"Jack-%d", arc4random_uniform(100)];
 56         int age = arc4random_uniform(20) + 30;
 57         NSString *sql = [NSString stringWithFormat:@"INSERT INTO t_student (name, age) VALUES (‘%@‘, %d);", name, age];
 58
 59         // 2.执行SQL语句
 60         char *erroMsg = NULL;
 61         sqlite3_exec(self.db, sql.UTF8String, NULL, NULL, &erroMsg);
 62         if (erroMsg) {
 63             NSLog(@"插入数据失败--%s", erroMsg);
 64         } else {
 65             NSLog(@"成功插入数据");
 66         }
 67     }
 68 }
 69
 70 - (IBAction)update {
 71     //与insert只有sql语句不同
 72 }
 73
 74 - (IBAction)delete {
 75     //与insert只有sql语句不同
 76 }
 77
 78 - (IBAction)select {
 79     const char *sql = "SELECT id, name, age FROM t_student WHERE age <= 30;";
 80     // 进行查询前的准备工作
 81     // -1 代表系统会自动计算SQL语句的长度
 82     // sqlite3_stmt:用来取数据
 83     sqlite3_stmt *stmt = NULL;
 84     if (sqlite3_prepare_v2(self.db, sql, -1, &stmt, NULL) == SQLITE_OK) { // SQL语句没有问题
 85         NSLog(@"查询语句没有问题");
 86
 87         // 每调一次sqlite3_step函数,stmt就会指向下一条记录
 88         while (sqlite3_step(stmt) == SQLITE_ROW) { // 找到一条记录
 89             // 取出数据
 90
 91             // 取出第0列字段的值(int类型的值)
 92             int ID = sqlite3_column_int(stmt, 0);
 93
 94             // 取出第1列字段的值(tex类型的值)
 95             const unsigned char *name = sqlite3_column_text(stmt, 1);
 96
 97             // 取出第2列字段的值(int类型的值)
 98             int age = sqlite3_column_int(stmt, 2);
 99
100             NSLog(@"%d %s %d", ID, name, age);
101         }
102     } else {
103         NSLog(@"查询语句有问题");
104     }
105 }
106 @end

IOS学习笔记-- SQLite的应用,布布扣,bubuko.com

时间: 2024-10-24 23:38:40

IOS学习笔记-- SQLite的应用的相关文章

iOS学习笔记16-数据库SQLite

一.数据库 在项目开发中,通常都需要对数据进行离线缓存的处理,如新闻数据的离线缓存等.离线缓存一般都是把数据保存到项目的沙盒中.有以下几种方式: 1. 归档:NSKeyedArchiver 2. 偏好设置:NSUserDefaults 3. plist存储:writeToFile 上述的使用可以参考iOS学习笔记15-序列化.偏好设置和归档,但上述三种方法都有一个致命的缺点,那就是都无法存储大批量的数据,有性能的问题,在这个时候就是使用数据库的时候. 数据库(Database)是按照数据结构来组

iOS 学习笔记——0005(数据存储)

先发一个练手的小demo,自己写的简略通讯录,已上传至github https://github.com/liaoshaolim/addressBook 1.NSKeyedArchiver:(归档) 这里用一个添加联系人的例子来说明: 注意:归档形式保存数据,需要该对象遵守NSCoding协议,而且对应的必须提供encodeWithCoder和initWithCoder方法 因为归档是一次性的,解压也是一次性的,所以小量的ok,如果量大的话,改一个小地方就要归档或解压全部,效率会比较低 //用一

ios学习笔记——数据持久化

一.沙盒 沙盒目录是一种数据安全策略,很多系统都采用沙盒设计. 沙盒目录设计的原理就是只能允许自己的应用程序访问目录,而不允许其他的应用访问. 1.Documents目录:该目录用于存储非常大的文件或非常频繁更新的数据,能够进行iTunes或iCloud的备份,获取目录位置的代码如下: 1 NSString * pathArr = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) la

iOS学习笔记(十六)——数据库操作(使用FMDB)

iOS中原生的SQLite API在使用上相当不友好,在使用时,非常不便.于是,就出现了一系列将SQLite API进行封装的库,例如FMDB.PlausibleDatabase.sqlitepersistentobjects等,FMDB (https://github.com/ccgus/fmdb) 是一款简洁.易用的封装库,这一篇文章简单介绍下FMDB的使用. 在FMDB下载文件后,工程中必须导入如下文件,并使用 libsqlite3.dylib 依赖包. FMDB同时兼容ARC和非ARC工

iOS学习笔记之UITableViewController&amp;UITableView

iOS学习笔记之UITableViewController&UITableView 写在前面 上个月末到现在一直都在忙实验室的事情,与导师讨论之后,发现目前在实验室完成的工作还不足以写成毕业论文,因此需要继续思考新的算法.这是一件挺痛苦的事情,特别是在很难找到与自己研究方向相关的文献的时候.也许网格序列水印这个课题本身的研究意义就是有待考证的.尽管如此,还是要努力的思考下去.由于实验室的原因,iOS的学习进度明显受到影响,加之整理文档本身是一件耗费时间和精力的事情,因此才这么久没有写笔记了. M

iOS: 学习笔记, Swift操作符定义

Swift操作符可以自行定义, 只需要加上简单的标志符即可. @infix 中置运算. 如+,-,*,/运算 @prefix 前置运算. 如- @postfix 后置运算. a++, a-- @assignment 赋值运算. +=, -=, --a, ++a // // main.swift // SwiftBasic // // Created by yao_yu on 14-7-27. // Copyright (c) 2014年 yao_yu. All rights reserved.

IOS学习笔记 -- Modal和Quartz2D

一. Modal1.Modal的默认效果:新控制器从屏幕的最底部往上钻,直到盖住之前的控制器为止;Modal只是改变了View的现实,没有改变rootViewController 2.常用方法1>.以Modal的形式展示控制器- (void)presentViewController:(UIViewController *)viewControllerToPresent animated: (BOOL)flag completion:(void (^)(void))completion2>.关

iOS: 学习笔记, 添加一个带界面约束的控制器

1. 创建一个空iOS应用程序(Empty Application). 2. 添加加控制器类. 修改控制器类的viewDidLoad 1 - (void)viewDidLoad 2 { 3 [super viewDidLoad]; 4 //创建标题 5 UILabel *header = [[UILabel alloc] init]; 6 header.text = @"欢迎来到我的世界!"; 7 header.textAlignment = NSTextAlignmentCenter

iOS学习笔记(2)— UIView用户事件响应

iOS学习笔记(2)— UIView用户事件响应 UIView除了负责展示内容给用户外还负责响应用户事件.本章主要介绍UIView用户交互相关的属性和方法. 1.交互相关的属性 userInteractionEnabled 默认是YES ,如果设置为NO则不响应用户事件,并且把当前控件从事件队列中删除.也就是说设置了userInterfaceEnabled属性的视图会打断响应者链导致该view的subview都无法响应事件. multipleTouchEnabled  默认是NO,如果设置为YE