首页 Qt数据库总结

Qt数据库总结

举报
开通vip

Qt数据库总结Qt数据库总结 #include QT += sql QSqlDatabase类实现了数据库连接的操作 QSqlQuery类用来执行SQL语句 QSqlRecord类封装数据库所有记录 第一:QSqlDatabase类 QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); 采用QSQLITE 数据库,QMYSQL数据库有问题? db.setHostName("localhost"); //设置数据库主机名 db.setDatabaseN...

Qt数据库总结
Qt数据库 总结 初级经济法重点总结下载党员个人总结TXt高中句型全总结.doc高中句型全总结.doc理论力学知识点总结pdf #include QT += sql QSqlDatabase类实现了数据库连接的操作 QSqlQuery类用来执行SQL语句 QSqlRecord类封装数据库所有记录 第一:QSqlDatabase类 QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); 采用QSQLITE 数据库,QMYSQL数据库有问题? db.setHostName("localhost"); //设置数据库主机名 db.setDatabaseName("test"); //设置数据库名 db.setUserName("root"); //设置数据库登入用户名 db.setPassword("123456"); //设计数据库登入密码 db.open()打开数据库连接 db.close();//释放数据库 QStringList drivers = QSqlDatabase::drivers();//静态成员函数,是类的成员函数,不是对象的.返回所有可用的数据库驱动程序的清单 drivers.removeAll("QMYSQL3"); //删除列表中的项 foreach(QString driver, drivers) //遍历数据库驱动,测试数据库驱动种类 qDebug() << “\t” << driver; 建立数据库文件 QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName("database.db"); if(!db.open()) return false; QSqlQuery query; query.exec("create table Login(id INTEGER PRIMARY KEY autoincrement, " //id会自动增加,因为这里不能重复,否则数据库无法修改 "goods int, store int, time nvarchar(50), type int, place nvarchar(50),temperature nvarchar(10) )"); //query.exec("insert into Login values(1,1002, 1,'2011-9-6',1,'common',24)"); // query.exec("insert into Login values(2,1005, 1,'2011-9-6',1,'common',24)"); //query.exec("insert into Login values(3,1010, 2,'2011-9-7',2,'common',25)"); // query.exec("insert into Login values(4,1012, 2,'2011-9-7',2,'common',25)"); query.exec("insert into Login values( 1,NULL , NULL,NULL, NULL,NULL,NULL )"); query.exec("insert into Login values( 2,NULL , NULL,NULL, NULL,NULL,NULL )"); query.exec("insert into Login values( 3,NULL , NULL,NULL, NULL,NULL,NULL )"); query.exec("insert into Login values( 4,NULL , NULL,NULL, NULL,NULL,NULL )"); query.exec("insert into Login values( 5,NULL , NULL,NULL, NULL,NULL,NULL )"); query.exec("insert into Login values( 6,NULL , NULL,NULL, NULL,NULL,NULL )"); 第二:QSqlQuery类,查询数据库,插入值到数据库等操作数据库 QSqlQuery query; query.prepare("INSERT INTO T_USER (name, age) VALUES (:name, :age)"); //准备执行SQL查询 query.bindValue(":name", "justin"); //在这定占位符上确定绑定的值query.bindValue(":age", 33); query.exec(); QSqlQuery query; //以下执行相关QSL语句 query.exec(“create table student(id int primary key,name varchar)”); //新建student表,id设置为主键,还有一个name项 query.exec(“insert into student values(1,’xiaogang’)”); query.exec(“insert into student values(2,’xiaoming’)”); query.exec(“insert into student values(3,’xiaohong’)”); //向表中插入3条记录 query.exec(“select * from student”); 来查询出表中所有的内容。其中的SQL语句“select * from student”中“*”号表明查询表中记录的所有属性。而当query.exec(“select * from student”); 这条语句执行完后,我们便获得了相应的执行结果,因为获得的结果可能不止一条记录,所以我们称之为结果集。 while(query.next()) QString name = query.value(0).toString(); //返回"name"字段的索引值"justin",value(i)返回i字段的值,0表示name,1表示age int id = query.value(1).toInt(); seek(int n) :query指向结果集的第n条记录。指定当前的位置 first() :query指向结果集的第一条记录。 last() :query指向结果集的最后一条记录。 next() :query指向下一条记录,每执行一次该函数,便指向相邻的下一条记录。 previous() :query指向上一条记录,每执行一次该函数,便指向相邻的上一条记录。 record() :获得现在指向的记录。 value(int n) :获得属性的值。其中n表示你查询的第n个属性,比方上面我们使用“select * from student”就相当于“select id, name from student”,那么value(0)返回id属性的值,value(1)返回name属性的值。该函数返回QVariant类型的数据,关于该类型与其他类型的对应关系,可以在帮助中查看QVariant。 at()//返回当前查询的位置 int fieldNo = query.record().indexOf(“name”);//返回"name"的列号 int rowNum = query.at(); //获取query所指向的记录在结果集中的编号 int columnNum = query.record().count(); //获取每条记录中属性(即列)的个数 int fieldNo = query.record().indexOf(“name”); //获取”name”属性所在列的编号,列从左向右编号,最左边的编号为0 int id = query.value(0).toInt(); //获取id属性的值,并转换为int型 QString name = query.value(fieldNo).toString(); //获取name属性的值 qDebug() << “rowNum is : ” << rowNum //将结果输出 << ” id is : ” << id << ” name is : ” << name << ” columnNum is : ” << columnNum; } if(query.seek(2)) //seek指定当前的位置 if(query.seek(ui->spinBox->value())) { qDebug() << query.value(0).toInt() << query.value(1).toString(); while(query.next()) //每执行一次该函数,便指向相邻的下一条记录。 { qDebug() << query.value(0).toInt() << query.value(1).toString(); //value(i)返回i字段的值,0表示id,1表示name } } //批处理操作函数--批量插入到数据库中 QSqlQuery q; q.prepare(“insert into student values (?, ?)”); QVariantList ints; //QVariantList==QList ints << 10 << 11 << 12 << 13; q.addBindValue(ints); //绑定 QVariantList names; names << “xiaoming” << “xiaoliang” << “xiaogang” << QVariant(QVariant::String); //最后一个是空字符串,应与前面的 格式 pdf格式笔记格式下载页码格式下载公文格式下载简报格式下载 相同 q.addBindValue(names); if (!q.execBatch()) //进行批处理,如果出错就输出错误 qDebug() << q.lastError(); //事务操作--操作函数transaction(),commit()提交,rollback()回滚 事务是数据库的一个重要功能,所谓事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。 在Qt中用transaction()开始一个事务操作,用commit()函数或rollback()函数进行结束。commit()表示提交,即提交事务的所有操作。 具体地说就是将事务中所有对数据库的更新写回到数据库,事务正常结束。rollback()表示回滚,即在事务运行的过程中发生了某种故障,事务不能继续进行, 系统将事务中对数据库的所有已完成的操作全部撤销,回滚到事务开始时的状态。 if(QSqlDatabase::database().driver()->hasFeature(QSqlDriver::Transact ions)) //先判断该数据库是否支持事务操作。hasFeature是QSQLDriver类函数 if(QSqlDatabase::database().transaction()) //启动事务操作 QModelIndex类 --用来定义数据模型中的数据 第三:QSqlQueryModel类只读数据模型为数据库结果集 函数:void QSqlQueryModel::setQuery ( const QString & query, const QSqlDatabase & db = QSqlDatabase() //执行访问query从给定的数据库db setHeaderData() //设置水平头标题 columnCount(); //获得列数 columnCount(); //获得列数 QSqlRecord QSqlQueryModel::record ( int row ) const //返回row行包含的信息 QModelIndex QAbstractItemModel::index ( int row, int column, const QModelIndex & parent = QModelIndex() ) //返回指定的行和列的确定的那个索引(index) index.data() //返回index索引的值 1. QSqlQueryModel *model = new QSqlQueryModel; model->setQuery("select * from student"); //查询整个student表的内容,访问给定的数据库 继续阅读
本文档为【Qt数据库总结】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_003124
暂无简介~
格式:doc
大小:26KB
软件:Word
页数:9
分类:互联网
上传时间:2018-11-30
浏览量:4