程序运行结果如下 :

输入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

SQLite 的简单使用的更多相关文章

  1. Win7下SQLite的简单使用

    前言 SQLite 是一个软件库,实现了自给自足的.无服务器的.零配置的.事务性的 SQL 数据库引擎.SQLite 是在世界上最广泛部署的 SQL 数据库引擎.SQLite 源代码不受版权限制. 简 ...

  2. 【SQLite】简单的基本使用步骤

    SQLite介绍SQLite is a software library that implements a self-contained, serverless, zero-configuratio ...

  3. IOS下SQLite的简单使用

    本文转载至 http://www.cnblogs.com/cokecoffe/archive/2012/05/31/2537105.html 看着国外网站的教程,写了一个小例子,一个联系人的程序,包括 ...

  4. Android SQLite 的简单实例

    1.前言: 今天再一次去蹭了一下某老师的android课,这一次讲的是Android的SQLite的使用,老师当场讲解了他自己做的例子. 回来之后,我春心萌动,不得不拿着参考资料再做了一个类似的例子, ...

  5. SQLite的简单应用

    安装部署 1)进入 SQL 下载页面:http://www.sqlite.org/download.html 2)下载预编译二进制文件包. Windows 环境的如下: 下载完之后,就算部署完成.(P ...

  6. Android学习笔记(SQLite的简单使用)

    1.SQLite介绍 SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中.它是D.RichardHipp建立的公有领域项目.它的设计目标是嵌入式的,而且 ...

  7. sqlite性能简单測试

    主要測试sqlite在大数据量下的插入及查询性能: 測试环境:Centos6.4  1G内存  单核 数据量 大小 索引字段检索(耗时) 非索引字段检索(耗时) 总插入时间 10W 19M 0.001 ...

  8. Android SQLite最简单demo实现(增删查改)

    本来不太想写这篇博客的,但是看到网上的关于android数据库操作的博文都讲得很详细,对于像我这样的新手入门了解SQLite的基本操作有一定难度,所以我参考了网上的一些博客文章,并自己亲自摸索了一遍, ...

  9. Android基础之sqlite 数据库简单操作

    尽管很简单,但是也存下来,以后直接粘过去就能用了. public class DBHelper extends SQLiteOpenHelper {      private static final ...

  10. Android SQLite(1)简单示例-增,删,改,查

    1.主要核心类,Sqlite编程要继承SQLiteOpenHelper import android.content.Context; import android.database.sqlite.S ...

随机推荐

  1. java中的finally用法总结

    不管 try 语句块正常结束还是异常结束,finally 语句块是保证要执行的.如果 try 语句块正常结束,那么在 try 语句块中的语句都执行完之后,再执行 finally 语句块.如果 try ...

  2. ModbusRTU模式和结束符(转)

    Modbus RTU模式的协议字段 起始位 设备地址 功能码 数据 CRC校验 结束符 至少3.5个字符 8bit 8bit N*8bit 16bit 至少3.5个字符 Modbus协议RTU模式要求 ...

  3. HTML5 Web SQL 数据库

    呼和浩特seo:Web SQL 数据库 API 并不是 HTML5 规范的一部分,但是它是一个独立的规范,引入了一组使用 SQL 操作客户端数据库的 APIs. 如果你是一个 Web 后端程序员,应该 ...

  4. HTML 003 元素

    HTML 元素 HTML 文档由 HTML 元素定义. HTML 元素 开始标签 * 元素内容 结束标签 * <p> 这是一个段落 </p> <a href=" ...

  5. DOM Diff(差分)算法

    1. 算法由来 React调用render()方法后,会生成一个React元素组成的树. 再次调用,生成一个新的树.React比较两者的差异,然后更新UI. 如果单纯使用算法,来查找两个DOM树的差异 ...

  6. P3038 [USACO11DEC]牧草种植Grass Planting

    题目描述 Farmer John has N barren pastures (2 <= N <= 100,000) connected by N-1 bidirectional road ...

  7. Centos7.x 安装 Supervisord

    [环境] 系统:Centos 7.3 软件:supervisord [安装Supervisord] yum install epel-release yum install -y supervisor ...

  8. Codeforces 1182D Complete Mirror [树哈希]

    Codeforces 中考考完之后第一个AC,纪念一下qwq 思路 简单理解一下题之后就可以发现其实就是要求一个点,使得把它提为根之后整棵树显得非常对称. 很容易想到树哈希来判结构是否相同,而且由于只 ...

  9. Java实体类为什么要实现序列化

    public class User implements Serializable {} 客户端访问了某个能开启会话功能的资源, web服务器就会创建一个与该客户端对应的HttpSession对象,每 ...

  10. Java知识体系思维导图

    Java知识体系,为方便预览,将思维导图上传至印象笔记,博客园直接上传图片受限于图片大小,暂时接触这么多,待以后丰富 https://app.yinxiang.com/shard/s24/nl/272 ...