[MFC]Sqlite问题小记

简介:

前言

  近几天弄Sqlite的C++程序被乱码、错误代码4和8整疯了,Sqlite的GUI工具使用的是Sqliteman。目前暂时可以用了,数据库为UTF-8的,但是在Sqliteman显示为乱码,程序中正常。

 

参考

  CppSQLite - C++ Wrapper for SQLite 

 

正文

  一、 使用Sqliteman创建UTF-8和auto_vacuum=1的数据库

    1.1  Sqliteman->New 创建新数据库

    1.2  左边菜单切换到Pragmas

    1.3  选中auto_vacuum这行,点击下方Change Value按钮,输入1,点确定

    1.4  选中encoding这行,同上,但是不能直接输入UTF-8,得输入UTF8或者"UTF-8"(带双引号)点确定

    1.5  最后随便新建一个表,然后退出即可。再次打开即可看到变更后效果,否则在已经存在表的数据库中你无法修改这两个值的。

 

  二、 使用sql语句来创建库和表

    上面用Sqliteman创建数据库并没有解决我的问题,仍然被乱码、错误代码4和8困扰,无奈之下只好用sql来创建和导入初始数据。在CppSQLiteDemo/CppSQLite3Demo.cpp的mian函数中直接写sql语句了,如下:

        remove(gszFile);
        db.open(gszFile);

        
// 创建config
        db.execDML( " create table config(id INTEGER, key TEXT, value TEXT, defaultvalue TEXT, desc TEXT); " );
        db.execDML(
" insert into config values ('1', 'IsAutoSync', '0', '1', '测试数据'); " );

    汉字部分用Sqliteman打开查看是仍然是乱码,但是程序读取出来没有问题。

 

  三、 注意

    3.1  本文使用的代码和库均是参考文章中的库和代码,从代码中可以看出是采用UTF-8打开的连接,使用的方法是sqlite3_open而不是sqlite3_open16,而Sqliteman默认是UTF-16le。

    3.2  CppSQLiteDemo下的工程为VC6的工程,打开后执行报错,你需要把Common/sqlite3.dll拷贝到Debug目录下即可。

 

  四、补充

    4.1  2010-5-21  想自动增长的话设置成INTEGER PRIMARY KEY就可以了,如下:

        db.execDML( " create table config(id INTEGER PRIMARY KEY, key TEXT, value TEXT, defaultvalue TEXT, desc TEXT); " );
        db.execDML(
" insert into config(key,value,defaultvalue,desc) values ('IsAutoSync', '0', '1', '测试'); " );


 

 

结束语

  发现文章是04年的 - - #,不过暂且先用着吧,等手头空了再翻新下,到时候再来一篇。


转载:http://www.cnblogs.com/over140/archive/2010/05/20/1740100.html

目录
相关文章
|
25天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
174 15
|
2月前
|
存储 SQL 数据库
数据库知识:了解SQLite或其他移动端数据库的使用
【10月更文挑战第22天】本文介绍了SQLite在移动应用开发中的应用,包括其优势、如何在Android中集成SQLite、基本的数据库操作(增删改查)、并发访问和事务处理等。通过示例代码,帮助开发者更好地理解和使用SQLite。此外,还提到了其他移动端数据库的选择。
52 8
|
3月前
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。
50 4
|
3月前
|
存储 关系型数据库 数据库
轻量级数据库的利器:Python 及其内置 SQLite 简介
轻量级数据库的利器:Python 及其内置 SQLite 简介
77 3
|
3月前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
4月前
|
存储 API 数据库
QML使用Sqlite数据库存储ListModel数据
本文介绍了在QML中使用Sqlite数据库存储ListModel数据的方法,包括如何创建数据库、读取数据、动态添加和删除数据,以及如何在程序启动和退出时与数据库同步数据。
104 2
|
4月前
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
244 1
|
3月前
|
存储 缓存 关系型数据库
sqlite 数据库 介绍
sqlite 数据库 介绍
58 0
|
5月前
|
人工智能 小程序 Java
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
本文介绍了一款名为PyWxDump的开源工具,它可以获取微信账户信息、解密SQLite数据库以查看和备份聊天记录。此工具适用于已登录电脑版微信的用户,通过GitHub下载后简单几步即可操作。适合对数据恢复感兴趣的开发者,但请注意合法合规使用并尊重隐私。
669 2
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
|
5月前
|
关系型数据库 Java MySQL
C#winform中使用SQLite数据库
C#winform中使用SQLite数据库
219 3
C#winform中使用SQLite数据库