c++获取sqlite3数据库表中所有字段的方法
常用方法:
1.使用sqlite3_get_table函数
2.获取sqlite创建表的sql语句字符串,然后进行解析获取到相应的字段
3.采用配置文件的方式,将所有字段名写入配置文件
方法1:使用sqlite3_get_table函数
代码:
char *dbname = “test.db”;
int rc = sqlite3_open(dbname, &db);
if (rc == SQLITE_OK)
{
char sql[] = “select * from Images” ;
char** pResult;
int nRow;
int nCol;
rc = sqlite3_get_table(db, sql, &pResult, &nRow, &nCol, NULL);
if (rc == SQLITE_OK)
{
if (nRow >= ){
...
}
}
sqlite3_free_table(pResult);
}
sqlite3_close(db);
分析:
nRow返回的是查询到的记录的行数(不包括字段名那一行),nCol返回的记录的列数,通过pResult可以访问所有返回的数据包括所有的字段名。如下图:

nRow=7,nCol=6,则pResult[0-5]返回的为当前这张表的字段名,每个字段名都是一个字符串数组。
该方法缺点:如果当前表中不存在记录时,将无法访问pResult[0 - nCol-1],这样就无法获取到表中字段。实际应用中经常需要在程序刚启动时就一次性先获取表中所有的字段名以便之后的插入删除更新等操作,所以该方法实用性不强。
方法2:获取sqlite创建表的sql语句字符串
过程分析:sqlite3在创建一个数据库以及对应的表之后会自动生成一个table,该table格式如下:

其中字段sql为创建表的create语句,通过sqlite3_get_table可以获取到指定表的create sql 语句,然后解析字符串就可以得到指定表中所有字段名。
代码:
//获取上图Figures表中create sql语句
string DB_GetFigureCreateSql()
{
string res = "";
int rc = sqlite3_open(dbname, &db);
if (rc == SQLITE_OK)
{
char *sql = "select sql from sqlite_master where tbl_name = 'Figures' and type = 'table'";
char** pResult;
int nRow;
int nCol;
rc = sqlite3_get_table(db, sql, &pResult, &nRow, &nCol, NULL);
if (rc == SQLITE_OK)
{
if (nRow >= )
{
res = pResult[nCol];
}
}
sqlite3_free_table(pResult);
}
sqlite3_close(db);
return res;
}
//解析字符串函数
std::vector<string> split(string str, string separator)
{
std::vector<string> result;
int cutAt;
while ((cutAt = str.find_first_of(separator)) != str.npos)
{
if (cutAt > )
{
result.push_back(str.substr(, cutAt));
}
str = str.substr(cutAt + );
}
if (str.length() > )
{
result.push_back(str);
}
return result;
}
//获取表中字段名
std::vector<string> DB_GetKeyFieldName(string res)
{
std::vector<string> r = split(res, ",");
std::vector<string> keyField;
for (int i = ; i < r.size(); ++i)
{
std::vector<string> tp = split(r[i], "\"");
if (tp.size() == )
{
keyField.push_back(tp[]);
}
else if (tp.size() == )
{
keyField.push_back(tp[]);
}
}
return keyField;
}
使用方法
std::vector<string> FieldName = DB_GetKeyFieldName(DB_GetFigureCreateSql());
结果分析:如果表中随时有可能添加新的字段,添加字段的sql语句,如下:
ALTER TABLE x ADD COLUMN "new_col",
其中new_col为字段名,双引号必须加上,因为上面解析的过程以双引号“ \””为分隔字符。(注意:sql语句中加双引号,单引号或者不加引号都可以成功的向指定表中添加字段)
方法3:采用配置文件的方式,将所有字段名写入配置文件
对于某些具体复杂的应用场景,可以采用配置文件的方式将所有字段名写入对应的配置文件中,每次进入应用程序时读取配置文件即可。另外如果某些字段有指定中可选的值,也可以将这些可选值也写入配置文件中。本人自己用的不规范的配置文件写法就不分享了,近期好好研究配置文件的规范写法。
本人暂时只使用过以上三种方法,如果有人任何错误,请及时与我联系。如果有更好的方法,还请留言分享,谢谢!
c++获取sqlite3数据库表中所有字段的方法的更多相关文章
- 【Java/JDBC】借助ResultSetMetaData,从数据库表中抽取字段信息存成Excel文件
本例工程下载:https://files.cnblogs.com/files/xiandedanteng/FindNotnullColumns20191102-3.rar 工作中曾有个为42张表建立测 ...
- 将文件导入到SQL server数据库表中的字段中
一.在要执行的sql server数据库a中执行如下脚本,创建存储过程sp_textcopy /* 将二进制文件导入.导出到数据库相应字段列中 */ CREATE PROCEDURE sp_textc ...
- oracle 中查看数据库表中某个字段是否重复
1.select 表中重复的字段 from 表名 group by 表中的重复的字段 HAVING count(表中的重复的字段)>1 举例说明 : 表名 : psp_cell_model ...
- 往sql数据库表中添加字段
通用式: alter table [表名] add [字段名] 字段属性 default 缺省值 default 是可选参数增加字段: alter table [表名] add 字段名 smallin ...
- java如何获得数据库表中各字段的字段名
public class TestDemo { public static Connection getConnection() { Connection conn = null; try { Cla ...
- mysql数据库表中判断字段是否存在,如果不存在则创建该字段
$key_answer = 'answer'.$question_num; $test_question = mysql_query('DESCRIBE question_manage {$key_q ...
- 用dataset做数据源时,让gridview显示的列名与数据库表中的字段名不同
原文发布时间为:2008-10-27 -- 来源于本人的百度文章 [由搬家工具导入] 确定GridView的AutoGenerateColumns设置为False;使用GridView的“编辑列”,添 ...
- FineUI之使用SQL脚本从数据库表中生成对应的输入控件
在WEB开发时.常常须要根据数据库表中的字段建立对应的输入控件,来获取输入的数据.每次都须要按字段来敲,显然太低效.并且easy出错.这里提供一个SQL脚本生成对应输入控件的方法. USE DBDem ...
- C# 获取SqLite数据库表信息以及获取表内字段信息
#region 最新数据表信息显示事件 /// <summary> /// 最新数据表信息显示事件 /// </summary> /// <param name=&quo ...
随机推荐
- net 数据库连接详解 相当经典啊
ADO.NET与抽水的故事 ADO.NET是微软新一代.NET数据库的访问架构,ADO是ActiveX Data Objects的缩写.ADO.NET是数据库应用程序和数据源之间沟通的桥梁,主要提供一 ...
- Urlencode and Urldecode 命令行
由于经常使用,简单记录之 $ alias urlencode='python -c "import sys, urllib as ul; print ul.quote_plus(sys.ar ...
- [Architecture Design] 跨平台架构设计
[Architecture Design] 跨平台架构设计 跨越平台 Productivity Future Vision 2011 在开始谈跨平台架构设计之前,请大家先看看上面这段影片,影片内容是微 ...
- js中的排序
不靠谱的sort() 众所周知,js中的sort()排序是按字母表顺序排序的,这就导致如下现象: var a = [9,60,111,55,8,7777]; a.sort(); alert(a); / ...
- canvas圆形进度条
通过定义一个canvas标签, new方法传进ID值,和旋转角度值,即可生成圆形进度条 <!DOCTYPE html> <html lang="en"> & ...
- SharePoint 2013 JQuery Asset Picket
var b = new AssetPickerConfig(""); b.ClientID = ""; b.DefaultAssetLocation = & ...
- Oracle EBS在编码方式为AL32UTF8时的注意事项
现如今的EBS系统中,为了推进国际化的进程,以及系统向全球化的扩展,在Oracle数据库的编码方式上渐渐从支持中国本土简体中文的ZHS16GBK转向了更趋于国际化的AL32UTF8编码方式.但随之而来 ...
- sudo gem install cocoapods 没反应问题
1. 尝试更新 sudo gem update --system 2. 查看安装详细 sudo gem install cocoapods -V 3.详细使用有个链接 http://blog.csdn ...
- AsyncTask.cancel()的结束问题
实际项目中有这么一个问题,用户进入详情界面,那么我们就要网络加载数据并展现在UI上,这个加载用线程或者异步. 这里就拿项目中统一用异步任务来获取网络数据把. 用户可能会有这么一个操作,它在一个商品(说 ...
- C语言预处理命令之条件编译
在C语言中,预处理指令是以#号开头的代码行.#号必须是该行除了任何空白字符外的第一个字符.#后是指令关键字,在关键字和#号之间允许存在任意个数的空白字符.整行语句构成了一条预处理指令,该指令将在编译器 ...