SQLite的基本使用-示例代码

SQLite的基本使用

//
//  IWViewController.m
//  01-SQLite的基本使用
//
//  Created by apple on 14-5-22.
//  Copyright (c) 2014年 itcast. All rights reserved.
//

#import "IWViewController.h"
#import <sqlite3.h>

@interface IWViewController ()
{
    // 成员变量默认=NULL
    sqlite3 *_db; // db代表着整个数据库,db是数据库实例
}
- (IBAction)insert;
- (IBAction)update;
- (IBAction)delete;
- (IBAction)query;
@end

@implementation IWViewController

- (void)viewDidLoad
{
    [super viewDidLoad];

    // 0.获得沙盒中的数据库文件名
    NSString *filename = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"student.sqlite"];

    NSLog(@"filename=====%@",filename);

    // 1.创建(打开)数据库(如果数据库文件不存在,会自动创建数据库main)
    int result = sqlite3_open(filename.UTF8String, &_db);
    if (result == SQLITE_OK) {
        NSLog(@"成功打开数据库");

        // 2.创表
        const char *sql = "create table if not exists t_student (id integer primary key autoincrement, name text, age integer);";

        // 为了严谨起见,凡是传递地址的,一般最初都要先清空。首先保证该变量是空指针,而不是野指针。
        char *errorMesg = NULL;

        // sqlite3_exec 执行SQL语句
        // 参数解释:第一个数据库实例,第二个SQL语句,第三个sqlite3_exec语句执行成功后的回调,第四个回调要传递的东西,第五个错误信息
        // C语言的空是大写的NULL
        // sqlite3_exec(<#sqlite3 *#>, <#const char *sql#>, <#int (*callback)(void *, int, char **, char **)#>, <#void *#>, <#char **errmsg#>)
        int result = sqlite3_exec(_db, sql, NULL, NULL, &errorMesg);
        if (result == SQLITE_OK) {
            NSLog(@"成功创建t_student表");
        } else {
            NSLog(@"创建t_student表失败:%s", errorMesg);// %s用来打印C语言的字符串
        }
    } else {
        NSLog(@"打开数据库失败");
    }
}

- (IBAction)insert
{
    for (int i = 0; i<30; i++) {
        NSString *name = [NSString stringWithFormat:@"Jack-%d", arc4random()%100];
        int age = arc4random()%100;
        NSString *sql = [NSString stringWithFormat:@"insert into t_student (name, age) values(‘%@‘, %d);", name, age];

        char *errorMesg = NULL;
        int result = sqlite3_exec(_db, sql.UTF8String, NULL, NULL, &errorMesg);
        if (result == SQLITE_OK) {
            NSLog(@"成功添加数据");
        } else {
            NSLog(@"添加数据失败:%s", errorMesg);
        }
    }
}

- (IBAction)query
{
    // SQL注入漏洞

    /**
     登录功能

     1.用户输入账号和密码
     * 账号:123‘ or 1 = 1 or ‘‘ = ‘
     * 密码:456654679

     2.拿到用户输入的账号和密码去数据库查询(查询有没有这个用户名和密码)
     select * from t_user where username = ‘123‘ and password = ‘456‘;

     select * from t_user where username = ‘123‘ and password = ‘456‘;
     */

    // 1.定义sql语句
    const char *sql = "select id, name, age from t_student where name = ?;";

    // 2.定义一个stmt来存放结果集
    sqlite3_stmt *stmt = NULL;

    // 3.检测SQL语句的合法性 第三个参数:SQL语句的长度,这里写-1会自动帮我们算SQL字符串的长度。最后一个参数:跟SQL语句尾部有关,此处先不写。
    int result = sqlite3_prepare_v2(_db, sql, -1, &stmt, NULL);
    if (result == SQLITE_OK) {
        NSLog(@"查询语句是合法的");

        /**
         sqlite3_bind_text():大部分绑定函数都只有3个参数
         第1个参数是sqlite3_stmt *类型
         第2个参数指占位符的位置,第一个占位符的位置是1,不是0,代表第几个问号
         第3个参数指占位符要绑定的值
         第4个参数指在第3个参数中所传递数据的长度,对于C字符串,传递-1会自动计算字符串的长度
         第5个参数是一个可选的函数回调,一般用于在语句执行后完成内存清理工作
         sqlite_step():执行SQL语句,返回SQLITE_DONE代表成功执行完毕
         sqlite_finalize():销毁sqlite3_stmt *对象
         */
        // 设置占位符的内容,用占位符的方式,会自动检测SQL注入情况,可有效防止SQL注入问题。
        sqlite3_bind_text(stmt, 1, "jack", -1, NULL);

        // 4.执行SQL语句,从结果集中取出数据
//        int stepResult = sqlite3_step(stmt);
        while (sqlite3_step(stmt) == SQLITE_ROW) { // 查询到一行数据
            // 获得这行对应的数据

            // 获得第0列的id
            int sid = sqlite3_column_int(stmt, 0);

            // 获得第1列的name
            const unsigned char *sname = sqlite3_column_text(stmt, 1);

            // 获得第2列的age
            int sage = sqlite3_column_int(stmt, 2);

            NSLog(@"%d %s %d", sid, sname, sage);
        }
    } else {
        NSLog(@"查询语句非合法");
    }
}
@end
时间: 2024-11-16 21:31:14

SQLite的基本使用-示例代码的相关文章

C/C++ 开源库及示例代码

C/C++ 开源库及示例代码 Table of Contents 说明 1 综合性的库 2 数据结构 & 算法 2.1 容器 2.1.1 标准容器 2.1.2 Lockfree 的容器 2.1.3 环形缓冲 2.1.4 多维数组 2.1.5 图 2.2 对容器的操作 2.3 字符串处理 2.3.1 字符集 2.3.2 字符串格式化 2.3.3 正则表达式 2.3.4 (其它) 2.4 内存相关 2.4.1 智能指针 2.4.2 内存池 2.5 时间 & 日期 2.6 编码 & 解码

10分钟理解Android数据库的创建与使用(附详解和示例代码)

1.Android数据库简介. Android系统的framework层集成了Sqlite3数据库,我们知道Sqlite3是一种轻量级的高效存储的数据库. Sqlite数据库具有以下优点: (1)零配置,无需安装和配置: (2)储存在单一磁盘文件中的一个完整的数据库: (3)数据库文件可以在不同字节顺序的机器间自由共享: (4)支持数据大小至2TB: (5)足够小,全部源代码大致3万行C代码,250KB: (6)比目前流行的大多数数据库的操作要快: (7)开源. 2.Sqlite 基本操作语句和

java第15章示例代码

import java.util.Scanner; /** * * @author asus第15章示例代码1 全桂群2017.4.9 * */public class Registter { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Scanner input = new Scanner(System.in); String uname, pw

左右JAVA示例代码事件分发和监督机制来实现-绝对原创有用

文章标题:左右JAVA示例代码事件分发和监督机制来实现 文章地址: http://blog.csdn.net/5iasp/article/details/37054171 作者: javaboy2012Email:[email protected]qq:    1046011462 一.场景如果 如果有博客系统中须要实现例如以下功能: 系统中用户公布文章.改动文章.删除文章时,须要一些相关的操作须要运行. 公布文章后,给好友发送邮件通知.给用户加积分,对文章做全文索引. 改动文章后,给好友发送邮

java 线程、线程池基本应用示例代码回顾

package org.rui.thread; /** * 定义任务 * * @author lenovo * */ public class LiftOff implements Runnable { protected int countDown=10; private static int taskCount=0; private final int id=taskCount++; public LiftOff(){} public LiftOff(int countDown) { thi

AppCan移动应用开发平台新增9个超实用插件(内含示例代码)

使用AppCan平台进行移动开发,你所需要具备的是Html5+CSS +JS前端语言基础,此外,Hybrid混合模式应用还需结合原生语言对功能模块进行封装,对于没有原生基础的开发者,如何实现App里包括支付.界面布局.地图导航.IM等功能呢? 这里列出9个AppCan新插件,在使用AppCan平台进行移动开发时非常实用. 1. uexInAppPurchase iOS内部支付IAP插件:封装内部支付IAP相关操作. 方法说明: getProductList 得到产品列表方法 purchase 购

rocketMQ的运行示例代码

rocketMQ的示例代码 1 import com.alibaba.rocketmq.client.exception.MQBrokerException; 2 import com.alibaba.rocketmq.client.exception.MQClientException; 3 import com.alibaba.rocketmq.client.producer.DefaultMQProducer; 4 import com.alibaba.rocketmq.client.pr

pyspider示例代码二:解析JSON数据

本系列文章主要记录和讲解pyspider的示例代码,希望能抛砖引玉.pyspider示例代码官方网站是http://demo.pyspider.org/.上面的示例代码太多,无从下手.因此本人找出一下比较经典的示例进行简单讲解,希望对新手有一些帮助. 示例说明: pyspider爬取的内容通过回调的参数response返回,response有多种解析方式.1.response.json用于解析json数据2.response.doc返回的是PyQuery对象3.response.etree返回的

jQuery中读取json文件示例代码

json文件是一种轻量级的数据交互格式.一般在jquery中使用getJSON()方法读取,具体示例代码如下,感兴趣的朋友可以参考下哈,希望可以帮助到你 json文件是一种轻量级的数据交互格式.一般在jquery中使用getJSON()方法读取. 复制代码 代码如下: $.getJSON(url,[data],[callback]) url:加载的页面地址 data: 可选项,发送到服务器的数据,格式是key/value callback:可选项,加载成功后执行的回调函数 1.首先建一个JSON