6225|4

333

帖子

0

TA的资源

一粒金砂(高级)

楼主
 

SQLite中插入数据,能不能插入一个数组? [复制链接]

我想在SQlite中插入数据,但是参考书上的做法是:
sql = \"INSERT INTO \'SensorData\' VALUES(NULL,1234);\";
sqlite3_exec(db,sql,0,0,&zErrMsg)
但是我不能每个数据都写一条代码,我的数据是接收来自远程的数据,不断变化,于是,我就想用一个数组存放接收的数据,然后插入这个数组:
char test[5];
sql = \"INSERT INTO \'SensorData\' VALUES(NULL,test);\";
sqlite3_exec(db,sql,0,0,&zErrMsg)
但是编译报错为:\"test unused\",可能把数组放在字符串中识别不出来了。
有没有办法解决插入一个不断变化的数据?


最新回复

本帖最后由 qiushenghua 于 2015-5-1 19:47 编辑 给一个最笨的范例吧: char test[5]; sql = "INSERT INTO \'SensorData\' VALUES(NULL,@@@@@);"; { unsigned char i=0; for(;sql[i]!='@';i++); sql[i]=test[0]; sql[i+1]=test[1];复制代码   详情 回复 发表于 2015-4-29 09:31
 
点赞 关注

回复
举报

1193

帖子

0

TA的资源

纯净的硅(高级)

沙发
 
当然有啦~
你要做的是字符串拼接
发现没有,sql其实只是一个字符串型的变量,你可以分一条语句或者多条语句对sql赋值,生成一句完整的sqlite语句,再考虑调用它。
 
 

回复

7608

帖子

2

TA的资源

五彩晶圆(高级)

板凳
 
两种基本方式,一是blob存数组,适合仅记录的场合,一是单条数据的批量插入,速度问题存储引擎自己优化,适合需要存储引擎参与计算的场合。另外最好用prepare构造。
 
 
 

回复

1193

帖子

0

TA的资源

纯净的硅(高级)

4
 
本帖最后由 qiushenghua 于 2015-5-1 19:47 编辑 给一个最笨的范例吧:
  1. char test[5];
  2. sql = "INSERT INTO \'SensorData\' VALUES(NULL,@@@@@);";
  3. {
  4. unsigned char i=0;
  5. for(;sql[i]!='@';i++);
  6. sql[i]=test[0];
  7. sql[i+1]=test[1];
复制代码

点评

后来做成功了,确实是您这种拼接字符串的思想,学习了!  详情 回复 发表于 2015-6-11 15:48
 
 
 

回复

333

帖子

0

TA的资源

一粒金砂(高级)

5
 
qiushenghua 发表于 2015-4-29 09:31
给一个最笨的范例吧:

后来做成功了,确实是您这种拼接字符串的思想,学习了!
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表