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

posted on 2015-10-06 20:03  玉思盈蝶  阅读(146)  评论(0编辑  收藏  举报

导航