一、创建(这里要说一下,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();
}
五、效果图