Qt数据库 利用QSqlQuery类执行SQL语句 中篇

移动开发
本文介绍的是Qt数据库 利用QSqlQuery类执行SQL语句,SQL即结构化查询语言,是关系数据库的标准语言。详细内容我们先来看内容。

Qt数据库 利用QSqlQuery类执行SQL语句 下篇是本节需要介绍的内容,接着上一篇教程。Qt数据库 利用QSqlQuery类执行SQL语句 上篇 ,也不多说了,直接看内容。

SQL语句中使用变量。

我们先看下面的一个例子,将“查询”按钮的槽函数更改如下:

  1. void Widget::on_pushButton_clicked()  
  2. {  
  3.     QSqlQuery query;  
  4.     query.prepare(“insert into student (id, name) ”  
  5.                   “values (:id, :name)”);  
  6.     query.bindValue(0, 5);  
  7.     query.bindValue(1, “sixth”);  
  8.     query.exec();  
  9.  
  10.     //下面输出最后一条记录  
  11.     query.exec(“select * from student”);  
  12.     query.last();  
  13.     int id = query.value(0).toInt();  
  14.     QString name = query.value(1).toString();  
  15.     qDebug() << id << name;  

运行效果如下:

Qt数据库 利用QSqlQuery类执行SQL语句 中篇

可以看到,在student表的最后又添加了一条记录。在上面的程序中,我们先使用了prepare()函数,在其中利用了“:id”和“:name”来代替具体的数据,而后又利用bindValue()函数给id和name两个属性赋值,这称为绑定操作。其中编号0和1分别代表“:id”和“:name”,就是说按照prepare()函数中出现的属性从左到右编号,最左边是0 。这里的“:id”和“:name”,叫做占位符,这是ODBC数据库的表示方法,还有一种Oracle的表示方法就是全部用“?”号。如下:

  1. query.prepare(“insert into student (id, name) ”  
  2.                   “values (?, ?)”);  
  3. query.bindValue(0, 5);  
  4. query.bindValue(1, “sixth”);  
  5. query.exec(); 

我们也可以利用addBindValue()函数,这样就可以省去编号,它是按顺序给属性赋值的,如下:

  1. query.prepare(“insert into student (id, name) ”  
  2.                   “values (?, ?)”);  
  3. query.addBindValue(5);  
  4. query.addBindValue(“sixth”);  
  5. query.exec(); 

当用ODBC的表示方法时,我们也可以将编号用实际的占位符代替,如下:

  1. query.prepare(“insert into student (id, name) ”  
  2.                       “values (:id, :name)”);  
  3. query.bindValue(“:id”, 5);  
  4. query.bindValue(“:name”, “sixth”);  
  5. query.exec(); 

以上各种形式的表示方式效果是一样的。特别注意,在最后一定要执行exec()函数,所做的操作才能被真正执行。

下面我们就可以利用绑定操作在SQL语句中使用变量了。

  1. void Widget::on_pushButton_clicked()  
  2. {  
  3.     QSqlQuery query;  
  4.     query.prepare(“select name from student where id = ?”);  
  5.     int id = ui->spinBox->value(); //从界面获取id的值  
  6.     query.addBindValue(id); //将id值进行绑定  
  7.     query.exec();  
  8.     query.next(); //指向第一条记录  
  9.     qDebug() << query.value(0).toString();  

运行程序,效果如下:

Qt数据库 利用QSqlQuery类执行SQL语句 中篇

我们改变spinBox的数值大小,然后按下“查询”按钮,可以看到对应的结果就出来了。

小结:Qt数据库 利用QSqlQuery类执行SQL语句 中篇的内容介绍完了,希望本节内容对你有帮助,想继续深入了解的话,请参考

Qt数据库 利用QSqlQuery类执行SQL语句 下篇

责任编辑:zhaolei 来源: 互联网
相关推荐

2011-06-27 14:17:35

Qt 数据库 QSqlQuery

2011-06-27 14:44:30

Qt 数据库 QSqlQuery

2011-08-15 14:29:52

SQL Server数事务

2010-09-07 15:20:58

SQL语句事务

2010-11-18 10:06:16

Oracle数据库性能

2011-06-21 15:31:04

Qt 数据库 SQL

2009-03-09 17:46:16

ASP.NETSQLOracle

2010-04-16 09:41:42

Oracle数据库查看

2011-01-06 09:28:19

SQL语句

2010-09-07 16:12:36

SQL语句数据库压缩

2011-09-09 10:10:13

SQL数据库点滴

2011-09-01 19:00:08

SQL ServerDBCC语句

2010-06-28 10:36:42

SQL Server数

2023-05-10 08:29:12

2010-05-11 10:12:50

mysql数据库sql

2019-03-01 18:50:09

SQL Server数据库备份并压缩

2010-07-15 15:37:13

SQL Server数

2010-07-02 08:23:06

SQL Server

2010-06-30 13:19:17

SQL Server

2011-03-31 09:30:27

SQL Server数管理SQL
点赞
收藏

51CTO技术栈公众号