首先,到官网下载相关的压缩包

https://www.sqlite.org/download.html

但是要自己再重新编译一个, 博主自己收集了一下,密码:hixo

https://pan.baidu.com/s/1Zdp0UMl2Mr4J2JUe28G7JQ

将该压缩包放在你想要放置的文件夹里,情况是这样的

然后在该路径下运行cmd,可以直接在地址栏中输入cmd并回车

然后输入 命令

sqlite3 databaseName.db

如果databaseName 名字的数据库在该路径下存在,则进入该数据库,如果不存在,则创建该数据库

然后就可以正常使用了, 如使用 .table 可以查看所有表, .exit可以退出(似乎这种数据库命令,不是sql语句的sqlite都是前面加 .)

该数据库允许navicat连接, (点连接,选择数据库位置即可)

接下去用 c++ 连接

当前示例数据库结构

table|user|user|2|CREATE TABLE "user" (
"id" INTEGER NOT NULL,
"account" TEXT(100),
"userName" TEXT(100),
"password" TEXT(100),
"address" TEXT(100),
"IDNumber" TEXT(100),
"openDate_year" INTEGER,
"openDate_month" INTEGER,
"openDate_day" INTEGER,
"isLost" INTEGER,
"lostDate_year" INTEGER,
"lostDate_month" INTEGER,
"lostDate_day" INTEGER,
"salt" TEXT,
PRIMARY KEY ("id" ASC)
)

基本读取

bool read() {
    sqlite3_stmt* stmt;        //编译的sql语句和操作的存储类
    sqlite3 * conn;            //用于保存与sqlite3的连接
    if (sqlite3_open("D:\\c++ study\\nicobank\\NicoNicoBank\\NicoNicoBank\\database\\bank.db", &conn) != SQLITE_OK) {
        return false;
    } //打开连接, 参数为数据库和sqlite3类
    
    sqlite3_prepare_v2(conn, "select * from user where account = \"test\";", -1, &stmt, 0);
    //预编译sql语句, 参数为,sqlite3类的连接(已打开),sql语句,可能是数据长度,填-1就会自己计算, sqlite3_stmt类, 最后一个我也不知道啥
    int result = sqlite3_step(stmt);
    while (sqlite3_step(stmt) == SQLITE_ROW) { //进行相关的执行步骤, 每次调用可以获取一行的值,因此可以多次调用
        int id = sqlite3_column_int(stmt, 0);
        cout << id << endl;    //获取当行指定列的值
    }
}

基本写入

bool write() {
sqlite3 * conn;
if (sqlite3_open("d:\\c++ study\\nicobank\\niconicobank\\niconicobank\\database\\bank.db", &conn) != SQLITE_OK) {
return false;
}
sqlite3_stmt * stmt = NULL;
string sql = "insert into user (account, userName, password, address, IDNumber, openDate_year,openDate_month, openDate_day, isLost, lostDate_year, lostDate_month, lostDate_day) values (?,?,?,?,?,?,?,?,?,?,?,?);";
//(id, account, username, password, address, idnumber, opendate_year,opendate_month, opendate_day, islost, lostdate_year, lostdate_month, lostdate_day)
sqlite3_prepare_v2(conn, sql.c_str(), -1, &stmt, 0);
//上述内容解释同read()
//需要注意的是?为占位符,可以通过sqlite3_bind_类型 这一组函数去绑定相关值,而问号位置是由1开始计算的
string a = "test";
string tempStr[5];
for (int i = 0; i < 5; i++) tempStr[i] = "str";
int tempInt[7];
for (int i = 0; i < 7; i++) tempInt[i] = 1;
//简单初始化一些数值用于传值 for (int i = 1; i <= 5; i++) {
sqlite3_bind_text(stmt, i, tempStr[i-1].c_str(), -1, NULL);
//绑定第1到第5个问号
//参数分别为stmt类, 问号位置,传入的值,字符串长度,-1则函数自行计算,我也不知道是啥但是可以填NULL的地方
}
for (int i = 6; i <= 12; i++) {
sqlite3_bind_int(stmt, i, tempInt[i-6]);
//绑定整数,stmt类,问号位置,传入值
}
int result = sqlite3_step(stmt); //执行命令
sqlite3_finalize(stmt); //关闭连接,避免
return false;
}

使用c++控制sqlite3的更多相关文章

  1. SQLite源程序分析之sqlite3.c

    /****************************************************************************** ** This file is an a ...

  2. sqlite3 shell的使用

    sqlite的安装 1. 首先是下载sqlite,可以该页面下载:http://www.sqlite.org/download.html 当前的最新版本为:sqlite-shell-win32-x86 ...

  3. SQLite3 学习笔记

    1.数据存储方式 Plist(NSArray\NSDictionary) Preference(偏好设置\NSUserDefaults) NSCoding(NSKeyedArchiver\NSkeye ...

  4. SQLITE3 使用总结

    转自: http://blog.chinaunix.net/uid-8447633-id-3321394.html 前序: Sqlite3 的确很好用.小巧.速度快.但是因为非微软的产品,帮助文档总觉 ...

  5. sqlite3常用命令&语法

    sqlite数据库只用一个文件就ok,小巧方便,所以是一个非常不错的嵌入式数据库,SQLite大量的被用于手机,PDA,MP3播放器以及机顶盒设备.    Mozilla Firefox使用SQLit ...

  6. sqlite3编程使用简介

    sqlite3使用范围 SQLite不同于其他大部分的SQL数据库引擎,因为它的首要设计目标就是简单化: 1.易于管理 2.易于使用 3.易于嵌入其他大型程序 4.易于维护和配置  许多人喜欢SQLi ...

  7. IOS异步和多线程操作&&在sqlite3中的应用

    1,数据库I/O操作(异步) 数据库本身是存储在磁盘上.访问和修改数据库,即对磁盘进行读写,即I/O操作. 磁盘属于计算机硬件,具有DMA能力,不需要CPU干预,可以实现异步操作. I/O操作一般是消 ...

  8. Ubuntu下sqlite3的安装及使用

    Sqlite是一款轻型的数据库,实现了多数SQL-92标准,包括事务(原子性,一致性,隔离性和持久性 ACID),触发器与多数复杂查询.对于一个移动手持设备的应用开发者,Sqlite是居家旅行必备数据 ...

  9. iOS sqlite3数据库解析

    看来从版本3.3.1基本上已经支持线程句柄的传递功能.具体限制我标记了一下.(6) Is SQLite threadsafe?SQLite is threadsafe. We make this co ...

随机推荐

  1. verilog if语句

    a.基本形式 1) if(表达式) 语句1: 2)if(表达式) 语句1: else 语句1 3) if(表达式1) 语句1: else   if(表达式2) 语句2: else   if(表达式3) ...

  2. Oracle错误——ORA-03113:通信通道的文件结尾

    请参考:http://blog.csdn.net/zwk626542417/article/details/39667999 今天跟往常一样,登陆PL/SQL,确登陆失败,出现一个错误“ORA-010 ...

  3. 异步对象(XMLHttpRequest)的帮助脚本

    异步对象五部曲 这是post请求的. //1.00创建异步对象 var xhr = new XMLHttpRequest(); //2.0 xhr.open("post", url ...

  4. input输入框不能获得焦点

    今天在ipad上遇到一个问题:jquery 调用 $(id).focus() 方法,失效,不能弹出键盘获得输入的焦点. 开始以为是 $(id).focus() 方法的问题,然后就试着用原声的docum ...

  5. node安装express时找不到pakage.json文件;判断安装成功?

    正常安装命令:express install express --save 报错如下:no such file or directory,open 'C:\Users\Administrator\pa ...

  6. window下隐藏apache版本和PHP脚本等敏感信息

    隐藏Apache信息 1.1 主配置中启用httpd-default.conf 文件: conf/httpd.Conf 找到httpd-default.conf,删除前面的注释“#”,改成如下 Inc ...

  7. css3实现iPhone滑动解锁

    该效果的主要实现思路是给文字添加渐变的背景,然后对背景进行裁剪,按文字裁剪(目前只有webkit内核浏览器支持该属性),最后给背景添加动画,即改变背景的位置,背景动画效果如下(GIF录制时有卡顿,代码 ...

  8. Android Studio 导入 AOSP 源码

    有了 AOSP 源码,接下来就是如何看了,可以直接文本看,可以用 Source Insight,我当然选择 Android Studio,Android Studio 是我熟悉且十分强大的工具.问题来 ...

  9. SqlServer存储过程中常用函数及操作

    1.case语句 用于选择语句 SELECT ProductNumber, Category = CASE ProductLine WHEN 'R' THEN 'Road' WHEN 'M' THEN ...

  10. python模块详解 XML

    XML模块 XML是实现不同语言或程序之间进行数据交换的协议,和json一样. XML格式: <?xml version="1.0" encoding="UTF-8 ...