SQLite 的简单使用
程序运行结果如下 :
输入name和age,点击"确认插入"按钮,即插入一条记录到数据库.
程序代码如下:(有详细注释,相信大家都看得懂哈!!!)
//
// ViewController.m
// 02 SQLite的基本操作
//
// Created by mac1 on 15/10/6.
// Copyright (c) 2015年 www.iphonetrain.com. All rights reserved.
//
#import "ViewController.h"
//导入库文件
#import <sqlite3.h>
@interface ViewController ()
//姓名
@property (weak, nonatomic) IBOutlet UITextField *nameTextField;
//年龄
@property (weak, nonatomic) IBOutlet UITextField *ageTextField;
@property (nonatomic,assign)sqlite3 *db; //全局变量默认为NULL
//"确认插入"按钮
- (IBAction)insertAction;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
//构建数据库的路径
NSString *dbFilePath = [NSHomeDirectory()stringByAppendingPathComponent:@"Documents/test.db"];
//打印数据库保存路径
NSLog(@"dbFilePath = %@",dbFilePath);
//1.创建数据库,如果没有数据库,则会创建
_db = NULL;
int status = sqlite3_open(dbFilePath.UTF8String, &_db);
if (status == SQLITE_OK) {
NSLog(@"打开数据库成功!");
//2.创建表
char *errmsg = NULL;
sqlite3_exec(_db, "CREATE TABLE IF NOT EXISTS t_user (id integer PRIMARY KEY ,name text, age integer)", NULL, NULL, &errmsg);
if (errmsg) {
NSLog(@"创建表失败!");
}
}
//查询数据
[self queryData];
}
//"确认插入"按钮被点击
- (IBAction)insertAction {
//DML 插入
NSString *insertSql = [NSString stringWithFormat:@"INSERT INTO t_user (name,age) VALUES ('%@','%ld')",_nameTextField.text,[_ageTextField.text integerValue]];
//插入数据
char *error = NULL;
sqlite3_exec(_db, insertSql.UTF8String, NULL, NULL, &error);
if (error) {
NSLog(@"插入记录失败!");
}
}
//DQL 查询语句的使用
- (void)queryData{
//准备查询(检查sql语句的合法性)
//参数值-1 表示程序内部计算大小
sqlite3_stmt *stmt = NULL;
int status = sqlite3_prepare_v2(_db, "SELECT * FROM t_user", -1, &stmt, NULL);
//表示有数据
if (status == SQLITE_OK) {
//sqlite3_step(stmt) == SQLITE_ROW 当前stmt指向的数据有值
while (sqlite3_step(stmt) == SQLITE_ROW) {
//取出一条数据中的name字段中的值
const unsigned char *name = sqlite3_column_text(stmt, 1);
//取出一条数据中的age字段中的值
int age = sqlite3_column_int(stmt, 2);
NSLog(@"name = %s , age = %d",name,age);
}
}
}
@end
不过,对数据库的操作,一般使用第三方框架 FMDB 操作
下载地址 :https://github.com/ccgus/fmdb