QT实战——QSql数据库

一、创建(这里要说一下,QSql需要我们引用lib库这里去博客或者其他地方自己找一下lib库文件即可)

在.pro文件中加入

QT       += sql

.h文件中引用到的

#include <QSqlDatabase>
#include <QSqlQuery>

首先,需要用到这两个

<QSqlDatabase>起到进行数据表的建立与链接的作用。
<QSqlQuery>起到对数据库操作的作用。

二、我的ui界面设计很简单

就进行简单的数据库功能实现(也是参考许多博客进行仿写)

三、简单的mysql的语法(这里注意一定要大写!!!!请仔细看下面的代码区)

创建一个数据库

格式为:create database 数据库名;

例:create database test;

创建一个表

格式为:create table 表名(内容 类型);

例:create table student(number int , name char(32), score double);

向表中插入信息

格式为:insert into 表名 values(表中的内容);

例:insert into student values(1, 'xiaoming', 99);

从表格中删除信息

格式为:delete from 表名 where 列名 = 条件;

例:delete  from student where name = 'xiaoming';

查询表中的内容

格式为:select 列名 from 表名 where 列名 = 条件;

例:select score from student where name = 'xiaoming';

我们可以用这样的语句查询所有的信息

select * from student;

修改表中的数据

格式为:update 表名 set 列名 = 新内容 where 列名 = 条件;

例:update student set score = 66 where name = 'xiaoming';

从数据库中删除一个表

格式为:drop table 表名;

例:drop table student;
详细参考:https://blog.csdn.net/y____xiang/article/details/80412247

                   https://www.cnblogs.com/lifexy/p/10921958.html

四、项目代码

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QSqlDatabase>
#include <QSqlQuery>
#include <QDebug>


namespace Ui {
class Widget;
}

class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = nullptr);
    ~Widget();

private slots:
    void on_btn_insert_clicked();

    void on_btn_delete_clicked();

    void on_btn_change_clicked();

    void on_btn_find_clicked();

    bool on_btn_close_clicked();

private:
    Ui::Widget *ui;

    QSqlDatabase db;//创建数据库
};

#endif // WIDGET_H

main.cpp

#include "widget.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();

    return a.exec();
}

widget.cpp

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);


    qDebug() << QSqlDatabase::drivers();//打印qt支持的数据库类型
    setWindowTitle("MYSQL");//设置窗口的标题

    db = QSqlDatabase::addDatabase("QSQLITE");//设置驱动,设置数据库类型,
//    db.setHostName("127.0.1.0");//设置主机名
    db.setDatabaseName("MyAdmin.dat");//设置数据库名
//    db.setUserName("admin");//设置用户名
//    db.setPassword("123");//设置密码
    if(db.open())
    {
        QSqlQuery query;
        //创建表
        bool success = query.exec("CREATE TABLE information ("
                                 "id INTEGER PRIMARY KEY AUTOINCREMENT, "
                                 "name VARCHAR(40) NOT NULL, "
                                 "num VARCHAR(40) NOT NULL, "
                                 "age VARCHAR(40) NOT NULL)");
        if(success)
        {
            qDebug()<<"creat success";
        }
        else
        {
            qDebug()<<"creat fail";
        }


        ui->TextEdit->appendPlainText("服务器打开成功");

    }
    else
    {
        ui->TextEdit->appendPlainText("服务器打开失败");
    }

}

Widget::~Widget()
{
    delete ui;
}

void Widget::on_btn_insert_clicked()
{
    /*向表中插入信息
    格式为:insert into 表名 values(表中的内容);
    例:insert into student values(1, 'xiaoming', 99);*/

    QString nameStr = ui->lineEdit_name->text();
    int num = ui->lineEdit_num->text().toInt();
    int age = ui->lineEdit_age->text().toInt();
    /*******************设置表格名称(information)(属性1(name),属性2(num),属性3(age))***************************/
    QString Str = QString("INSERT INTO information (name,num,age)"
                          "VALUES ('%1','%2','%3')").arg(nameStr).arg(num).arg(age);

    QSqlQuery query;//执行SQL的语法
    query.exec(Str);
    if(query.exec(Str))
    {
      ui->TextEdit->appendPlainText(QString("name = %1 , num = %2 , age = %3").arg(nameStr).arg(num).arg(age));
      ui->TextEdit->appendPlainText(Str + "插入成功");
    }
    else
    {
      ui->TextEdit->appendPlainText(Str + "插入失败");
    }
}

void Widget::on_btn_delete_clicked()
{
    /*从表格中删除信息
      格式为:delete from 表名 where 列名 = 条件;
      例:delete  from student where name = 'xiaoming';*/

    QString nameStr = ui->lineEdit_name->text();
    int num = ui->lineEdit_num->text().toInt();
    int age = ui->lineEdit_age->text().toInt();

    QString Str = QString("DELETE FROM information WHERE name = '%1' AND num = '%2' AND age = '%3'").arg(nameStr).arg(num).arg(age);

    QSqlQuery query;//执行SQL的语法
    bool success = query.exec(Str);
    if(success)
    {
        ui->TextEdit->appendPlainText(Str + "删除成功");
    }
    else
    {
        ui->TextEdit->appendPlainText(Str + "删除失败");
    }


}

void Widget::on_btn_change_clicked()
{
    /*修改表中的数据
      格式为:update 表名 set 列名 = 新内容 where 列名 = 条件;
      例:update student set score = 66 where name = 'xiaoming';*/
    QString updatenameStr = ui->lineEdit_name->text();
    int updatenum = ui->lineEdit_num->text().toInt();
    int updateage = ui->lineEdit_age->text().toInt();

    QString temp = QString("UPDATE information SET num = '%1' , age = '%2' WHERE name = '%3'").arg(updatenum).arg(updateage).arg(updatenameStr);

    QSqlQuery query;//执行SQL的语法
    query.prepare(temp);
    bool success = query.exec();
    if(success)
    {
        ui->TextEdit->appendPlainText(updatenameStr + "修改成功");
    }
    else
    {
        ui->TextEdit->appendPlainText(updatenameStr + "修改失败");
        return;
    }

}

void Widget::on_btn_find_clicked()
{
    /*查询表中的内容
    格式为:select 列名 from 表名 where 列名 = 条件;
    例:select score from student where name = 'xiaoming';
    我们可以用这样的语句查询所有的信息
    select * from student;*/

    //根据人名查信息
    QString searchName = ui->lineEdit_name->text();

    QString Str = QString("SELECT * FROM information WHERE name = '%1'").arg(searchName);


    QSqlQuery query;
    query.exec(Str);
    QString name;
    int num;
    int age;

    while (query.next())
    {
        name = query.value(1).toString();
        num= query.value(2).toInt();
        age =  query.value(3).toInt();
    }

    ui->TextEdit->appendPlainText(QString("name = %1 , num = %2 , age = %3").arg(name).arg(num).arg(age));
    ui->TextEdit->appendPlainText("查询成功");


}

bool Widget::on_btn_close_clicked()
{
     db.close();
     ui->TextEdit->appendPlainText("数据库关闭");
     this->close();
}

五、效果图

 

  • 6
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值