sqlmodel.pro
#-------------------------------------------------
#
# Project created by QtCreator 2019-09-03T11:03:21
#
#-------------------------------------------------
QT += core gui sql
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
TARGET = sqlmodel
TEMPLATE = app
# The following define makes your compiler emit warnings if you use
# any feature of Qt which as been marked as deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS
# You can also make your code fail to compile if you use deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
SOURCES += main.cpp\
mainwindow.cpp
HEADERS += mainwindow.h \
connection.h
FORMS += mainwindow.ui
connection.h
#ifndef CONNECTION_H
#define CONNECTION_H
#include <QMessageBox>
#include <QSqlDatabase>
#include <QSqlQuery>
#include <QCoreApplication>
static bool createConnection()
{
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
QString dataPath = QCoreApplication::applicationDirPath()+"/my.db";
db.setDatabaseName(dataPath);
if(!db.open())
{
QMessageBox::critical(0,"cannot open database","Unable to establish a database connection.",
QMessageBox::Cancel);
return false;
}
QSqlQuery query;
query.exec("create table student(id int primary key,name varchar,course int)");
query.exec("insert into student values(1,'李强',11)");
query.exec("insert into student values(2,'马亮',11)");
query.exec("insert into student values(3,'孙红',12)");
//创建course表
query.exec("create table coures(id int primary key,name varchar,teacher varchar)");
query.exec("insert into course values(10,'数学','王老师')");
query.exec("insert into course values(10,'英语','张老师')");
query.exec("insert into course values(10,'计算机','白老师')");
return true;
}
#endif // CONNECTION_H
main.cpp
#include "mainwindow.h"
#include <QApplication>
#include "connection.h"
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
if(!createConnection()) return 1;
MainWindow w;
w.show();
return a.exec();
}
mainwindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QSqlQueryModel>
#include <QSqlTableModel>
#include <QSqlRelationalTableModel>
#include <QTableView>
#include <QDebug>
#include <QMessageBox>
#include <QSqlError>
#include "connection.h"
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
QSqlQueryModel* model = new QSqlQueryModel(this);
model->setQuery("select * from student");
model->setHeaderData(0,Qt::Horizontal,tr("学号"));
model->setHeaderData(1,Qt::Horizontal,tr("姓名"));
model->setHeaderData(2,Qt::Horizontal,tr("课程"));
QTableView * view = new QTableView(this);
view->setModel(model);
setCentralWidget(view);
}
MainWindow::~MainWindow()
{
delete ui;
}
运算结果: