qt怎样创建数据库以及数据库的操作

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了qt怎样创建数据库以及数据库的操作相关的知识,希望对你有一定的参考价值。

QT创建和插入的操作代码如下:
bool database::createDatabase()

QSqlQuery query; // 此处请查询 query的相关操作
qDebug() << "Start to create table...";
//create table: User
query.exec("CREATE TABLE [User] ( [userId] VARCHAR(40) NOT NULL, [username] VARCHAR(40) NOT NULL, [email] VARCHAR(40), [password] VARCHAR(40), [city] VARCHAR(20), PRIMARY KEY([userId]) )"); // 一定注意不要拼写错误,引号内是不提示拼写错误的。
//create table: Connect
query.exec("CREATE TABLE [Connect] ( [LeftUser] VARCHAR(40) NOT NULL, [RightUser] VARCHAR(40) NOT NULL, [relation] INTEGER DEFAULT \'0\' NULL, PRIMARY KEY ([LeftUser], [RightUser]))");
if (query.lastError().isValid())

qDebug() << query.lastError();
return false;

else

qDebug() << "Create database successfully.";

return true;

插入操作

bool database::adduser( User user )

if (!db.isOpen())

createconnection();

QSqlQuery query;
qDebug() << "start to insert data";
query.exec("INSERT INTO [User] ( userId, username, email, password, city) VALUES(?,?,?,?,?)");
QVariantList userId;
userId << user.getUserId();
query.addBindValue(userId);
QVariantList username;
username << user.getUserName();
query.addBindValue(username);
QVariantList email;
email << user.getEmail();
query.addBindValue(email);
QVariantList password;
password << user.getPassword();
query.addBindValue(password);
QVariantList city;
city << user.getCity();
query.addBindValue(city);
try

if (!query.execBatch())

qDebug() << query.lastQuery();
qDebug() << query.lastError();
return NULL;


catch(...)

QMessageBox::critical(0, "Add New Node error!",
"Unable to add a new Node!/n/n"
"Click Cancel to exit.", QMessageBox::Cancel);

if( !UpdateConnectTable(user.getUserId(),user.getUserId(),2))

QMessageBox::critical(0,"","Update table Connect error");
return NULL;

return true;
参考技术A qt可以实现连接各种数据库,这里介绍qt自带的一种数据库(Qsqlite)#include<QSqlQuery>#include<QObject>#include<QVariantList>#include<QDebug>#include<QSqlError>#include<QTextCodec>#include<QObject>staticboolcreateConnection()QSqlDatabasedb=QSqlDatabase::addDatabase("QSQLITE");db.setDatabaseName("mytest.db");if(!db.open())returnfalse;QSqlQueryquery;//query.exec(QObject::tr("createtablestudent(idintprimarykey,namevchar)"));//query.exec(QObject::tr("insertintostudentvalues(0,'刘')"));////query.exec(QObject::tr("insertintostudentvalues(1,'刚')"));//query.exec(QObject::tr("insertintostudentvalues(2,'红')"));//query.prepare("insertintostudentvalues(?,?)");//-------------------------------------------------------//通过下面这段代码可以实现向数据库插入变量//--------------------------------------------------------QVariantListages;intx1,x2,x3,x4;x1=12;x2=13;x3=14;x4=15;ages<<x1<<x2<<x3<<x4;query.addBindValue(ages);QVariantListnames;names<<QObject::tr("小王")<<QObject::tr("小明")<<QObject::tr("小张")<<QObject::tr("小新");//如果要提交空串,用QVariant(QVariant::String)代替名字query.addBindValue(names);if(!query.execBatch())//进行批处理,如果出错就输出错误qDebug()<<query.lastError();returntrue;#endif//DATABASE_H然后用QSqlTableModel实现数据库数据显示本回答被提问者采纳

Qt之操作数据库(SQLite)实例

QtSql模块提供了与平台以及数据库种类无关的访问SQL数据库的接口,这个接口由利用Qt的模型视图结构将数据库与用户界面集成的一套类来支持。
QSqlDatabase对象象征了数据库的关联。Qt使用驱动程序与各种数据库的应用编程接口进行通信。Qt的桌面版(Desktop Edition)包括如下一些驱动程序:

 驱动程序 数据库 
 QDB2 IBM DB2 7.1版以及更新的版本 
 QIBASE Borland InterBase
 QMYSQL MySql 
 QOCI 甲骨文公司(Oracle Call Interface)
 QODBC ODBC(包括微软公司的QSL服务)
 QPSQL PostgreSQL的7.3版以及更高版本 
 QSQLITE QSLite第3版 
 QSQLITE2 QSLite第2版

 QTDS Qybase自适应服务器 

 

访问QSqlite数据库的实例:

步骤:

1、创建Qt控制台程序。

2、在pro问价中添加QT +=sql;

3、在main.cpp中添加如下代码

#include <QCoreApplication>  
#include <QSql>  
#include <QSqlDatabase>  
#include <QSqlError>  
#include <QSqlQuery>  
#include <QString>  
#include <QFile>  
#include <QDebug>  
#include <QVariantList>  
  
int main(int argc, char *argv[])  
{  
    QCoreApplication a(argc, argv);  
  
    QSqlDatabase database = QSqlDatabase::addDatabase("QSQLITE");  
  
    database.setDatabaseName("CashSystem.db");  
  
    if(database.open())  
    {  
        qDebug()<<"Database Opened";  
  
        QSqlQuery sql_query;  
        QString create_sql = "create table member (id int primary key, name varchar(30), address varchar(30))"; //创建数据表  
        QString insert_sql = "insert into member values(?,?,?)";    //插入数据  
  
        QString select_all_sql = "select * from member";  
  
        sql_query.prepare(create_sql); //创建表  
        if(!sql_query.exec()) //查看创建表是否成功  
        {  
            qDebug()<<QObject::tr("Table Create failed");  
            qDebug()<<sql_query.lastError();  
        }  
        else  
        {  
            qDebug()<< "Table Created" ;  
  
            //插入数据  
            sql_query.prepare(insert_sql);  
  
            QVariantList GroupIDs;  
            GroupIDs.append(0);  
            GroupIDs.append(1);  
            GroupIDs.append(2);  
  
            QVariantList GroupNames;  
            GroupNames.append("hsp");  
            GroupNames.append("rl");  
            GroupNames.append("spl");  
  
            QVariantList GroupAddress;  
            GroupAddress.append("南充");  
            GroupAddress.append("宝鸡");  
            GroupAddress.append("南充");  
  
            sql_query.addBindValue(GroupIDs);  
            sql_query.addBindValue(GroupNames);  
            sql_query.addBindValue(GroupAddress);  
  
            if(!sql_query.execBatch())  
            {  
                qDebug()<<sql_query.lastError();  
            }  
            else  
            {  
                qDebug()<<"插入记录成功";  
            }  
  
            //查询所有记录  
            sql_query.prepare(select_all_sql);  
            if(!sql_query.exec())  
            {  
                qDebug()<<sql_query.lastError();  
            }  
            else  
            {  
                while(sql_query.next())  
                {  
                    int id = sql_query.value(0).toInt();  
                    QString name = sql_query.value(1).toString();  
                    QString address = sql_query.value(2).toString();  
                    qDebug()<<QString("ID:%1  Name:%2  Address:%3").arg(id).arg(name).arg(address);  
                }  
            }  
        }  
    }  
    database.close();  
   // QFile::remove("CashSystem.db");  
    return a.exec();  
} 

4、运行截图:

5、在项目的debug文件夹下,生成了对应的.db文件,使用navicat forSqlite工具打开,显示结果如下:

 

参考链接:

1、Qt之操作数据库(SQLite)实例

2、Qt---自带的数据库QSQLITE

3、在Qt中使用SQLite数据库

 

以上是关于qt怎样创建数据库以及数据库的操作的主要内容,如果未能解决你的问题,请参考以下文章

QT操作mysql数据库(创建,插入,更新,删除)

42.QT-QSqlQuery类操作SQLite数据库(创建查询删除修改)详解

Qt编译mysql以及创建表后进行导入操作

sql server中怎样创建保存数据的存储过程

Qt 史上最详细 - “操作XML文件” - 笔记

Qt:将数据库存储/创建到用户空间