Qt5.5.0使用mysql编写小软件源码讲解---顾客信息登记表

简介: Qt5.5.0使用mysql编写小软件源码讲解---顾客信息登记表 一个个人觉得比较简单小巧的软件。 下面就如何编写如何发布打包来介绍一下吧! 先下载mysql的库文件链接:http://files.cnblogs.com/files/xiaobo-Linux/mysql.zip 把两个文件放入 Qt目录\Qt5.5.0\5.5\mingw492_32\bin文件夹下直接粘贴(路径根据自己的设置) 也可以放到原来工程代码中,头文件用双引号引出即可。
+关注继续查看

Qt5.5.0使用mysql编写小软件源码讲解---顾客信息登记表

一个个人觉得比较简单小巧的软件。

下面就如何编写如何发布打包来介绍一下吧!

先下载mysql的库文件链接:http://files.cnblogs.com/files/xiaobo-Linux/mysql.zip

把两个文件放入 Qt目录\Qt5.5.0\5.5\mingw492_32\bin文件夹下直接粘贴(路径根据自己的设置)

也可以放到原来工程代码中,头文件用双引号引出即可。

<!--小波Linux QQ463431476 cnblogs http://www.cnblogs.com/xiaobo-Linux/ -->

在.pro文件里输入


Qt += sql

然后执行以下Qmake识别mysql

这样在头文件中引用库函数即可了:

 

mysql语句的使用跟sqlite3使用方法是一样的。

不多说来先,下面看源码就懂啦!

pro

#-------------------------------------------------
#
# Project created by 小波Linux QQ463431476 cnblogs http://www.cnblogs.com/xiaobo-Linux/ QtCreator 2016-01-29T20:59:48
#
#-------------------------------------------------

QT       += core gui
QT += sql

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

TARGET = usersdata
TEMPLATE = app


SOURCES += main.cpp\
        mainwindow.cpp

HEADERS  += mainwindow.h

FORMS    += mainwindow.ui

RESOURCES += \
    icon.qrc
RC_FILE=icon.rc

 

.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QSqlDatabase> //数据库类
#include <QSqlQuery>    //执行语句类
#include <QSqlRecord>   //返回记录类
#include <QtSql>
#include <QApplication>
#include <QMessageBox>
#include <iostream>
#include <QtDebug>
//#include <QAbstractTableModel>
namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    explicit MainWindow(QWidget *parent = 0);
    ~MainWindow();


private slots:

  void on_save_clicked();
  void on_del_clicked();
  void select();
  void on_search_clicked();
  void on_back_clicked();

//小波Linux QQ463431476 cnblogs http://www.cnblogs.com/xiaobo-Linux/
private:
    Ui::MainWindow *ui;
};

#endif // MAINWINDOW_H

main。cpp

主要是链接db文件

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

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    //创建DB文件,创建表格
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    std::cout<<"begin sqlite"<<std::endl;
    db.setDatabaseName("userdata.db");
    if ( !db.open()){
    QMessageBox::critical(NULL, QObject::tr("Collection"), QObject::tr("failed to connect to database!"));
    return 0;
    }
    QSqlQuery query;
    query.exec("create table userdata (会员编号 integer PRIMARY KEY ,姓名 text,性别 text,登记日期 text,手机号1 int,手机号2 int,备注 text)");


    MainWindow w;
    w.show();

    return a.exec();
}//小波Linux QQ463431476 cnblogs http://www.cnblogs.com/xiaobo-Linux/


mainwindow.cpp

具体的实现代码

//小波Linux QQ463431476 cnblogs http://www.cnblogs.com/xiaobo-Linux/
#include "mainwindow.h" #include "ui_mainwindow.h" MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); setWindowTitle("会员信息登记表"); setWindowIcon(QIcon("xiaobo.ico"));//设置软件图标 select();//显示表格 } MainWindow::~MainWindow() { delete ui; } void MainWindow::on_save_clicked() { QSqlQuery query; query.prepare("insert into userdata (会员编号,姓名,性别,登记日期,手机号1,手机号2,备注)values(:id,:name ,:sex,:date,:phone1,:phone2,:mark )"); query.bindValue(":id",ui->textEdit_9->toPlainText()); query.bindValue(":name",ui->textEdit->toPlainText()); query.bindValue(":sex",ui->textEdit_5->toPlainText()); query.bindValue(":date",ui->textEdit_6->toPlainText()); query.bindValue(":phone1",ui->textEdit_2->toPlainText()); query.bindValue(":phone2",ui->textEdit_3->toPlainText()); query.bindValue(":mark",ui->textEdit_7->toPlainText()); query.exec(); select(); QMessageBox::information(this,"提示","用户信息保存成功!"); } void MainWindow::on_del_clicked() { QSqlQuery query; int curRow = ui->tableView->currentIndex().row(); //鼠标选择删除第几行 QModelIndex index = ui->tableView->currentIndex(); int id=index.sibling(curRow,0).data().toInt(); query.prepare("delete from userdata where 会员编号 = :id"); query.bindValue(":id",id); query.exec(); select(); } void MainWindow::select() { QSqlQueryModel *model = new QSqlQueryModel(ui->tableView); model->setQuery(QString("select *from userdata")); ui->tableView->setModel(model); } void MainWindow::on_search_clicked() { QSqlQuery query; ui ->tableView -> clearSpans(); //tableview清空 QSqlQueryModel *model = new QSqlQueryModel(ui->tableView); query.prepare("select *from userdata where 姓名 = :name "); //like模糊查询没成功 query.bindValue(":name",ui->textEdit_8->text()); query.exec(); model->setQuery(query); ui->tableView->setModel(model); } void MainWindow::on_back_clicked() { select(); }

 

 

  Qt model和tableview的使用:  http://www.cnblogs.com/xiaobo-Linux/p/5176432.html

 

ui

 

 

 

rc资源图片加入

添加ico : http://www.cnblogs.com/xiaobo-Linux/p/5176432.html

 

软件演示:

 

 

 

 

最后形成一个独立的软件exe格式:Qt使用自带的windeployqt 生成exe来发布软件 : http://www.cnblogs.com/xiaobo-Linux/p/4678026.html

 

然后软件的安装打包:

最后用个打包软件来发布软件吧!!

 

这样就行了。

 

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
人工智能 运维 监控
Java智慧工地云平台源码(微服务+Java+Spring Cloud +UniApp +MySql)
Java智慧工地云平台源码(微服务+Java+Spring Cloud +UniApp +MySql)
204 0
|
2月前
|
SQL 数据库
Springboot+html5+mysql的CRUD增删改查(基础版本详细,附带源码)(二)
Springboot+html5+mysql的CRUD增删改查(基础版本详细,附带源码)(二)
23 0
|
2月前
|
SQL 数据库连接
Springboot+html5+mysql的CRUD增删改查(基础版本详细,附带源码)(一)
Springboot+html5+mysql的CRUD增删改查(基础版本详细,附带源码)(一)
31 0
|
4月前
|
SQL 存储 关系型数据库
【MySQL学习笔记】系列三:演示使用MySQL、介绍图形化管理工具、MySQL的目录结构与源码(二)
【MySQL学习笔记】系列三:演示使用MySQL、介绍图形化管理工具、MySQL的目录结构与源码(二)
|
4月前
|
SQL 监控 安全
【MySQL学习笔记】系列三:演示使用MySQL、介绍图形化管理工具、MySQL的目录结构与源码(一)
【MySQL学习笔记】系列三:演示使用MySQL、介绍图形化管理工具、MySQL的目录结构与源码(一)
|
7月前
|
存储 SQL 缓存
万字长文~vue+express+mysql带你彻底搞懂项目中的权限控制(附所有源码)
万字长文~vue+express+mysql带你彻底搞懂项目中的权限控制(附所有源码)
170 0
|
7月前
|
前端开发 NoSQL Java
java Swing+mysql+JDBC实现教务系统(源码+数据库+UML图+数据库分析)
🍅程序员小王的博客:程序员小王的博客 🍅 欢迎点赞 👍 收藏 ⭐留言 📝 🍅 如有编辑错误联系作者,如果有比较好的文章欢迎分享给我,我会取其精华去其糟粕 🍅java自学的学习路线:java自学的学习路线
207 0
java Swing+mysql+JDBC实现教务系统(源码+数据库+UML图+数据库分析)
|
存储 缓存 关系型数据库
【MySQL 源码】UNION 比 UNION ALL 的性能差很多吗?
本文从源码角度分析了一下 MySQL 中 union 和 union all 的区别;得出了以下结论: union 和 union all 都会创建临时表, 但是又不太一样; 二者的查询计划不一样;union 默认会创建一个以返回列作为 key 的临时表, 所谓过滤就是将数据插入这个临时表; 临时表装数据的容器实际上是一个 unordered_set; 有一种存储引擎叫做临时表; union all 则是直接读取表的数据并返回给客户端, 不走临时表; union all 和 union 的场景还是得根据需要来判断, 如果没有 distinct 的需求话, 数据又不多, 可以考虑使用 union
242 0
【MySQL 源码】UNION 比 UNION ALL 的性能差很多吗?
|
SQL 关系型数据库 MySQL
golang日常开发系列之三--mysql driver常见问题和源码解析
golang日常开发系列之三--mysql driver常见问题和源码解析
314 0
|
SQL 存储 安全
MySQL 8.0 MVCC 源码解析
本文在此基础上,对 MVCC 展开详细的分析,同时修改了之前的一些不太准确的说法,希望可以助你在面试中更好的发(zhuang)挥(bi)。
413 0
MySQL 8.0 MVCC 源码解析
推荐文章
更多