基于Qt5.5.0的sql,C++备忘录软件的编写
我的第一个软件。
基于Qt5.5.0的 sql ,C++备忘录软件version1.0的编写
我用的Qt版本是5.5.0免配置编译器的版本,这里附上我使用的软件下载地址:http://download.qt.io/official_releases/qt/5.5/5.5.0/ 下载 qt-opensource-windows-x86-mingw492-5.5.0.exe即可。
话不多说,第一先是基于Qt5.5.0的sql的配置,这里详见我的另外一篇博客:http://www.cnblogs.com/xiaobo-Linux/p/4674986.html
此时,sql环境配置好,编写代码。
附上我的代码:
++++++++++++++++++project.pro里面的代码++++++++++++++++
#-------------------------------------------------
#
# Project created by QtCreator --21T13::
#
#-------------------------------------------------
QT += core gui
QT += sql # 引用数据库
greaterThan(QT_MAJOR_VERSION, ): QT += widgets
TARGET = project3
TEMPLATE = app
SOURCES += main.cpp\
reminder.cpp
HEADERS += reminder.h
FORMS += reminder.ui
#DESTDIR += C:// # 编译文件输出路径,不加此句默认在工程文件下创建.dbRC_FILE=icon.rc #添加软件图标
+++++++++++++++++++reminder.h的头文件代码+++++++++++++++++++++++
#ifndef REMINDER_H
#define REMINDER_H
#include <QMainWindow>
#include <QSqlDatabase> //数据库类
#include <QSqlQuery> //执行语句类
//#include <QSqlRecord> //返回记录类
#include <QtSql>
#include <QApplication>
#include <QMessageBox>
#include <iostream>
//#include <QtDebug>
namespace Ui {
class Reminder;
}
class Reminder : public QMainWindow
{
Q_OBJECT
public:
);
~Reminder();
private slots:
void on_save_clicked();
void on_del_clicked();
void select();
void on_search_clicked();
void on_back_clicked();
private:
Ui::Reminder *ui;
QSqlDatabase db; //声明数据库类
};
#endif // REMINDER_H
++++++++++++++++++++++++main.cpp代码+++++++++++++++++++++++++++++
#include "reminder.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("reminder.db");
if ( !db.open()){
QMessageBox::critical(NULL, QObject::tr("Collection"), QObject::tr("failed to connect to database!"));
;
}
QSqlQuery query;
query.exec("create table reminder (id integer PRIMARY KEY AUTOINCREMENT,主题 text,内容 text)");
Reminder w;
w.show();
return a.exec();
}
+++++++++++++++++reminder.cpp代码+++++++++++++++++
#include "reminder.h"
#include "ui_reminder.h"
Reminder::Reminder(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::Reminder)
{
ui->setupUi(this);
setWindowTitle("小波的提醒备忘录V1.0"); setWindowIcon(QIcon("xiaobo.ico"));//设置软件图标
select();//显示表格
}
Reminder::~Reminder()
{
db.close();
delete ui;
}
void Reminder::on_save_clicked()
{
QSqlQuery query;
query.prepare("insert into reminder (id,主题,内容)values(1:theme , :content )"); //id自动增加,先从1起,之后无需手动插入
query.prepare("insert into reminder (主题,内容)values(:theme , :content )");
query.bindValue(":theme",ui->textEdit->text()); //从输入框插入数据
query.bindValue(":content",ui->textEdit_2->toPlainText());
query.exec();
select();//显示表格
}
void Reminder::on_del_clicked()
{
QSqlQuery query;
int curRow = ui->tableView->currentIndex().row(); //鼠标选择删除第几行
QModelIndex index = ui->tableView->currentIndex();
).data().toInt();
query.prepare("delete from reminder where id = :id");
query.bindValue(":id",id);
query.exec();
select();
}
void Reminder::select()
{ //将sql表格显示到tableView里
QSqlQueryModel *model = new QSqlQueryModel(ui->tableView);
model->setQuery(QString("select *from reminder"));
model->setHeaderData(,Qt::Horizontal,QObject::tr("ID"));
model->setHeaderData(,Qt::Horizontal,QObject::tr("主题"));
model->setHeaderData(,Qt::Horizontal,QObject::tr("内容"));
ui->tableView->setModel(model);
}
void Reminder::on_search_clicked()
{ QSqlQuery query;
ui -> tableView -> clearSpans(); //tableview清空
QSqlQueryModel *model = new QSqlQueryModel(ui->tableView);
query.prepare("select *from reminder where 主题 = :theme "); //like模糊查询没成功
query.bindValue(":theme",ui->textEdit_3->text());
query.exec();
model->setQuery(query);
model->setHeaderData(,Qt::Horizontal,QObject::tr("ID"));
model->setHeaderData(,Qt::Horizontal,QObject::tr("主题"));
model->setHeaderData(,Qt::Horizontal,QObject::tr("内容"));
ui->tableView->setModel(model);
}
void Reminder::on_back_clicked()
{
select();
}
++++++++++++++++reminder.ui++++++++++++++++++++++++++++

=============== 下面是演示软件的演示情况 ================
------------------------主界面 ------------------------------

-----------------检索---------------------------

Qt为生成的软件添加图标的方法:
1. 准备好ico图标文件名字为 xiaobo.ico,最好放在和.pro文件同一个文件夹中
这里在线生成的图标地址:http://www.ico.la/
2.创建一个叫icon.rc的文件,里面写上文本信息IDI_ICON1 ICON " xiaobo.ico",保存好
3.在pro文件中添加代码:RC_FILE=icon.rc
4.在MainWindow的构造函数中添加setWindowIcon(QIcon(" xiaobo.ico"));
5.再重新运行就ok了

======最后来发布软件=========
Qt使用自带的windeployqt 生成exe来发布软件,详见我的另外一篇博客:http://www.cnblogs.com/xiaobo-Linux/p/4678026.html
基于Qt5.5.0的sql,C++备忘录软件的编写的更多相关文章
- 基于Qt5.5.0的sql数据库、SDK_tts文本语音朗读的CET四六级单词背诵系统软件的编写V1.0
作者:小波 QQ:463431476 请关注我的博客园:http://www.cnblogs.com/xiaobo-Linux/ 我的第二款软件:CET四六级单词背诵软件.基于QT5.5.0.sql数 ...
- 基于Spark1.3.0的Spark sql三个核心部分
基于Spark1.3.0的Spark sql三个核心部分: 1.可以架子啊各种结构化数据源(JSON,Hive,and Parquet) 2.可以让你通过SQL,saprk内部程序或者外部攻击,通过标 ...
- linux下编译qt5.6.0静态库——configure配置
linux下编译qt5.6.0静态库 linux下编译qt5.6.0静态库 configure生成makefile 安装选项 Configure选项 第三方库: 附加选项: QNX/Blackberr ...
- linux下编译qt5.6.0静态库——configure配置(超详细,有每一个模块的说明)(乌合之众)
linux下编译qt5.6.0静态库 linux下编译qt5.6.0静态库 configure生成makefile 安装选项 Configure选项 第三方库: 附加选项: QNX/Blackberr ...
- linux下编译qt5.6.0静态库(使用./configure --help来看看都有哪些参数。超详细,有每一个模块的说明。如果改变了安装的目录,需要到安装目录下的bin目录下创建文件qt.conf)(乌合之众)good
linux下编译qt5.6.0静态库 linux下编译qt5.6.0静态库 configure生成makefile 安装选项 Configure选项 第三方库: 附加选项: QNX/Blackberr ...
- Qt5.7.0配置选项(configure非常详细的参数)
configure是一个命令行工具,用于配置Qt编译到指定平台.configure必须运行于Qt源码根目录.当运行configure时,编译源码使用的是所选工具链中的make工具. 一.源码目录.编译 ...
- 使用Qt5.7.0 VS2015版本生成兼容XP的可执行程序 good(从VS2012 update1开始支持xp和c++11)
一.直接使用VS2012/VS2013/VS2015生成XP兼容的可执行程序 Visual Studio刚发布时没打补丁,称为RTM版,之后会陆续发布补丁,进行bug修复和功能增强.VS2010及之前 ...
- VS2015编译Qt5.7.0生成支持XP的静态库(很不错)
一.编译工具 1.VS2015 编译Qt5.7.0的所需VS版本:Visual Studio 2013 (Update1)或Visual Studio 2015 (Update2).因为Update补 ...
- Win7(32bit)下Qt5.5.0和OpenCV2.4.9环境的搭建
之前一直基于Windows平台(Win 7 32bit)使用VS2010做OpenCV的开发,现在开始学习在Windows 下使用Qt做OpenCV的开发.本文主要讲述Windows平台下(Win 7 ...
随机推荐
- 「轉」Java的内存机制
0.参考资料: http://www.j2megame.org/index.php/content/view/2246/125.html 1.Java的内存机制 Java 把内存划分成两种:一种是栈内 ...
- OGNl和ValueStack的基础和深入分析
一.OGNL 1)什么是OGNL? 解析:OGNL是Object Graph Navigation Language(对象图导航语言)它是强大的表达式语言. 2)用途:通过简单一致的表达式语法来读取和 ...
- Java基础学习 -- Java(OOP)程序的设计原则
避免代码复制.解决方案:函数.父类: 封装.尽量private每个类的成员变量,用操作封装数据,减少类与类之间成员变量的直接调用,而是调用method,降低耦合: 可扩展性最大化.尽量使用框架+数据的 ...
- heX——基于 HTML5 和 Node.JS 开发桌面应用
heX 是网易有道团队的一个开源项目,允许你采用前端技术(HTML,CSS,JavaScript)开发桌面应用软件的跨平台解决方案.heX 是你开发桌面应用的一种新的选择,意在解决传统桌面应用开发中繁 ...
- 高性能javascript学习笔记系列(4) -算法和流程控制
参考高性能javascript for in 循环 使用它可以遍历对象的属性名,但是每次的操作都会搜索实例或者原型的属性 导致使用for in 进行遍历会产生更多的开销 书中提到不要使用for in ...
- 原创QQ影音DLL劫持漏洞+动画实战教程
1.什么是DLL DLL(Dynamic Link Library)文件为动态链接库文件,又称“应用程序拓展”,是软件文件类型.在Windows中,许多应用程序并不是一个完整的可执行文件,它们被分割成 ...
- flume 集群安装
./pssh -h ./host/all.txt -P mkdir /usr/local/app ./pssh -h ./host/all.txt -P tar zxf /usr/local/soft ...
- 好推二维码如何通过应用宝微下载支持微信自动打开APP下载?
好推二维码 官网 http://www.hotapp.cn 1. 为什么使用应用宝微下载? APP下载二维码,通过微信扫描下载的时候,微信目前只支持应用宝微下载,才能在微信里直接打开下载,否则就需要在 ...
- .Net控件经验集合
一.DropDownList默认选中 开始的笨方法: foreach (ListItem item in DropDownList1.Items) { ...
- iOS--(UITableViewCell)、(UITableViewController)微信个人主页
本文主要实现了微信的个人主页的设置: 目录文件如下: 实现代码如下: RootTableViewController.h #import <UIKit/UIKit.h> @interfac ...