sql使用exec执行QString字符串时的注意点

30 篇文章 4 订阅
1 篇文章 0 订阅

在Qt中,为了动态生成sql语句并执行,惯用的做法是生成一个可编辑的QString字符串,然后利用arg()函数补全QString。如下:

	QSqlQuery query(*mQSqlDatabase);
	int v1=1;
	int v2=2;
	QString str=QString("insert into table(val1) values('%1')").arg(v1);
	query.exec(str);

这里需要特别注意的是包围在%1外面的单引号。如果不加这个单引号,可能会出现一切意料之外的问题。

1.创建语句

	QString tableName="test";
	QString str=QString("create table %1(id integer Primary key,val1 varchar(32))").arg(tableName);
	query.exec(str);

在创建语句中,不需要在%1,即表名上添加单引号。

2.插入语句

	QSqlQuery query(*mQSqlDatabase);
	int v1=1;
	int v2=2;
	QString str=QString("insert into table(val1) values('%1')").arg(v1);
	query.exec(str);

此时在赋值的时候需要加单引号。

3.查询语句

	QSqlQuery query(*mQSqlDatabase);
	QString tableName="test";
	int v1=1;
	QString str=QString("select * from %1 where  val1='%2'").arg(tableName).arg(v1);
	query.exec(str);

在表格名处未加单引号,在表格的值的地方,加了。

4.结论

在涉及到表格内的值的sql操作时,尽量加上单引号,避免出问题。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鱼月半

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值