Qt基于sqlite数据库的管理小软件
闲来无事,写了一个基于sqlite的数据库管理小软件。
先上图
中心思想就是:
创建一个数据库 然后每一个分组对应一个数据表 然后遍历该数据表。将名字以treewidgetItem显示出来。添加删除实质上是对数据库在操作。不想写太多功能,写多了就成了数据库的桌面管理版了(嘻嘻开玩笑的题外话)。
下面贴代码:
Administrater::Administrater(QWidget *parent)
: QMainWindow(parent)
{
QSqlDatabase Administrater=QSqlDatabase::addDatabase("QSQLITE");
Administrater.setDatabaseName("Administrater.db");
Administrater.open(); _query=QSqlQuery(Administrater); _query.prepare("create table goldVip(name varchar(20),sex varchar(10),ID char(20))");
_query.exec(); _query.prepare("create table Vip(name varchar(50),sex varchar(10),ID char(20))");
_query.exec(); _query.prepare("create table Coustomer(name varchar(20),sex varchar(10),ID char(20))");
_query.exec(); _query.prepare("select count(*) from goldVip");
_query.exec();
_query.next();
_a=_query.value().toInt(); _query.prepare("select count(*) from Vip");
_query.exec();
_query.next();
_b=_query.value().toInt(); _query.prepare("select count(*) from Coustomer");
_query.exec();
_query.next();
_c=_query.value().toInt(); this->setGeometry(,,,);
_treeWidget = new QTreeWidget(this);
_treeWidget->setColumnCount();
_treeWidget->setHeaderLabel("联系人"); _treeWidget->setStyleSheet("color: blue;"
"background-color: yellow;"
"selection-color: yellow;"
"selection-background-color: blue;"); _Item=new QTreeWidgetItem(_treeWidget);
_Item->setText(,"黄金vip");
// _Item->setCheckState(0, Qt::Checked);//复选框
_Item->setIcon(,QIcon("1.ico"));
int i=;
_query.prepare("select * from goldVip");
_query.exec();
while(i<_a)
{
_query.next();
QTreeWidgetItem *Item=new QTreeWidgetItem;
Item->setText(,_query.value().toString());
_Item->addChild(Item);
++i;
} // connect(_Item,SIGNAL(itemClicked(QTreeWidgetItem *Item,int index)),this,
// SLOT(slotItem(QTreeWidgetItem *Item,int index))); _Item2=new QTreeWidgetItem(_treeWidget);
_Item2->setText(,"普通vip");
_Item2->setIcon(,QIcon("2.ico"));
i=;
_query.prepare("select * from Vip");
_query.exec();
while(i<_b)
{
_query.next();
QTreeWidgetItem *Item=new QTreeWidgetItem;
Item->setText(,_query.value().toString());
_Item2->addChild(Item);
++i;
} _Item3=new QTreeWidgetItem(_treeWidget);
_Item3->setText(,"普通客户");
_Item3->setIcon(,QIcon("3.ico"));
i=;
_query.prepare("select * from Coustomer");
_query.exec();
while(i<_c)
{
_query.next();
QTreeWidgetItem *Item=new QTreeWidgetItem;
Item->setText(,_query.value().toString());
_Item3->addChild(Item);
++i;
} //Administrater.close(); QMenuBar *menuBar=QMainWindow::menuBar();
this->setMenuBar(menuBar); QAction *Action=new QAction("添加",this);
QAction *Action2=new QAction("删除",this);
QAction *Action3=new QAction("查询",this);
QList<QAction *>_list;
_list<<Action<<Action2<<Action3;
menuBar->addActions(_list); connect(Action,SIGNAL(triggered(bool)),this,SLOT(slotAction()));
connect(Action2,SIGNAL(triggered(bool)),this,SLOT(slotAction2()));
connect(Action3,SIGNAL(triggered(bool)),this,SLOT(slotAction3())); } Administrater::~Administrater()
{ }
void Administrater::resizeEvent(QResizeEvent *)
{
_treeWidget->setGeometry(,,this->width(),this->height()); }
void Administrater::slotAction2()
{
Delete *w2=new Delete;
w2->show();
connect(w2,SIGNAL(delete_sucess()),this,SLOT(update_show()));
}
void Administrater::slotAction()
{
Deal *w=new Deal;
w->show(); w->setStyleSheet("background-color: rgb(255, 252, 162);"); connect(w,SIGNAL(add_sucess()),SLOT(update_show())); }
void Administrater::slotAction3()
{
Find *w3=new Find;
w3->show();
}
void Administrater::update_show()
{
delete _Item;
delete _Item2;
delete _Item3; _Item=new QTreeWidgetItem(_treeWidget);
_Item->setText(,"黄金vip");
// _Item->setCheckState(0, Qt::Checked);//复选框
_Item->setIcon(,QIcon("1.ico")); _Item2=new QTreeWidgetItem(_treeWidget);
_Item2->setText(,"普通vip");
_Item2->setIcon(,QIcon("2.ico")); _Item3=new QTreeWidgetItem(_treeWidget);
_Item3->setText(,"普通客户");
_Item3->setIcon(,QIcon("3.ico")); _query.prepare("select count(*) from goldVip");
_query.exec();
_query.next();
_a=_query.value().toInt(); _query.prepare("select count(*) from Vip");
_query.exec();
_query.next();
_b=_query.value().toInt(); _query.prepare("select count(*) from Coustomer");
_query.exec();
_query.next();
_c=_query.value().toInt(); // _Item->removeChild();
int i=;
_query.prepare("select * from goldVip");
_query.exec();
while(i<_a)
{
_query.next();
QTreeWidgetItem *Item=new QTreeWidgetItem;
Item->setText(,_query.value().toString());
_Item->addChild(Item);
++i;
} // connect(_Item,SIGNAL(itemClicked(QTreeWidgetItem *Item,int index)),this,
// SLOT(slotItem(QTreeWidgetItem *Item,int index))); i=;
_query.prepare("select * from Vip");
_query.exec();
while(i<_b)
{
_query.next();
QTreeWidgetItem *Item=new QTreeWidgetItem;
Item->setText(,_query.value().toString());
_Item2->addChild(Item);
++i;
} i=;
_query.prepare("select * from Coustomer");
_query.exec();
while(i<_c)
{
_query.next();
QTreeWidgetItem *Item=new QTreeWidgetItem;
Item->setText(,_query.value().toString());
_Item3->addChild(Item);
++i;
} }
#include "Deal.h"
#include "ui_Deal.h"
#include<QtSql/QSqlDatabase>
#include<QSqlQuery>
#include<QDebug>
#include<QComboBox>
#include<QMessageBox>
Deal::Deal(QWidget *parent) :
QWidget(parent),
ui(new Ui::Deal)
{
ui->setupUi(this);
connect(ui->comboBox,SIGNAL(activated(int)),
this,SLOT(on_comboBox_activated(int d)));
this->setStyleSheet("QLineEdit{background-color: red}");
ui->lineEdit->setStyleSheet("background-color: rgb(188, 255, 207);");
ui->lineEdit_2->setStyleSheet("background-color: rgb(188, 255, 207);");
ui->lineEdit_3->setStyleSheet("background-color: rgb(188, 255, 207);");
} Deal::~Deal()
{
delete ui;
} void Deal::on_pushButton_clicked()
{ QSqlQuery query; QString str=ui->lineEdit->text();
QString str2=ui->lineEdit_2->text();
QString str3=ui->lineEdit_3->text(); if(_Kind.isEmpty())
{
QMessageBox::information(this,"温馨提示","你还没有选者客户分类",QMessageBox::Ok);
return;
}
QString str4=QString("insert into ")+_Kind+QString(" values(")+
QString("\'")+str+QString("\'")+QString(",")+
QString("\'")+str2+QString("\'")+QString(",")+
QString("\'")+str3+QString("\'")+
QString(")");
query.prepare(str4);
if(query.exec())
{
QMessageBox *messageBox=new QMessageBox(QMessageBox::Information,
"温馨提示","添加成功",QMessageBox::Ok);
messageBox->show();
_timer=new QTimer(this);
_timer->start(1200);
connect(_timer,SIGNAL(timeout()),messageBox,SLOT(close()));
emit add_sucess();
}
else
{
qDebug()<<"falied";
} } void Deal::on_comboBox_activated(int s)
{ if(ui->lineEdit->text().isEmpty()|ui->lineEdit_2->text().isEmpty()|
ui->lineEdit_3->text().isEmpty())
{
QMessageBox::information(this,"温馨提示:","你输入的资料不完整",QMessageBox::Ok);
}
if(s==0)
{
_Kind="goldVip";
}
else if(s==1)
{
_Kind="Vip";
}
else if(s==2)
{
_Kind="Coustomer";
} }
#include "Delete.h"
#include "ui_Delete.h"
#include<QSqlQuery>
#include<QDebug>
#include<QMessageBox>
#include<QTimer>
#include<QPalette>
Delete::Delete(QWidget *parent) :
QWidget(parent),
ui(new Ui::Delete)
{
ui->setupUi(this);
} Delete::~Delete()
{
delete ui;
} void Delete::on_pushButton_clicked()
{
QString str=ui->lineEdit->text();
QString str2="delete from ";
QString str3=" where name=";
QString str4=str2+_Str+str3+QString("\'")+str+QString("\'");
QSqlQuery query;
query.prepare(str4);
if(query.exec())
{
QMessageBox *messageBox=new QMessageBox(QMessageBox::Information,
"温馨提示","删除成功",QMessageBox::Ok);
messageBox->show();
QTimer *timer=new QTimer(this);
timer->start(1200);
connect(timer,SIGNAL(timeout()),messageBox,SLOT(close()));
emit delete_sucess();
}
else
{
QMessageBox *messageBox=new QMessageBox(QMessageBox::Information,
"温馨提示","该分组下无该用户",
QMessageBox::Ok);
}
} void Delete::on_comboBox_activated(int index)
{
if(index==0)
{
_Str="goldVip";
}
else if(index==1)
{
_Str="Vip";
}
else if(index==2)
{
_Str="Coustomer";
}
}
#include "Find.h"
#include "ui_Find.h"
#include<QSqlQuery>
#include<QMessageBox>
#include<QPalette>
Find::Find(QWidget *parent) :
QWidget(parent),
ui(new Ui::Find)
{
ui->setupUi(this);
_lists<<"姓名:"<<"性别:"<<"ID:";
QPalette pal=this->palette();
pal.setBrush(QPalette::Background,Qt::green);
this->setPalette(pal); } Find::~Find()
{
delete ui;
} void Find::on_pushButton_clicked()
{
if(_Str.isEmpty())
{
QMessageBox::information(this,"警告","你未选择客户类型",QMessageBox::Ok);
}
QString str=ui->lineEdit->text();
QString str2="select * from "+_Str+QString(" where name=")
+ QString("\'")+str+QString("\'");
QSqlQuery query;
query.prepare(str2);
if(query.exec())
{
query.next();
if(query.value(0).toString().isEmpty())
{
QMessageBox::warning(this,"警告","该数据库查无此人",QMessageBox::Ok);
return;
}
while(!query.value(0).toString().isEmpty())
{
for(int i=0;i<3;++i)
{ ui->textBrowser->append(_lists.at(i)+query.value(i).toString()); }
query.next();
} }
else
{
QMessageBox *messageBox=new QMessageBox(QMessageBox::Information,
"温馨提示","该分组下无该用户",
QMessageBox::Ok);
}
} void Find::on_comboBox_activated(int index)
{ if(index==0)
{
_Str="goldVip";
}
else if(index==1)
{
_Str="Vip";
}
else if(index==2)
{
_Str="Coustomer";
}
}
顺便提一句 sqlite是没有表头的 所以用query去提取数据时 先next下才有数据的哈。
Qt基于sqlite数据库的管理小软件的更多相关文章
- Qt 操作SQLite数据库
项目中通常需要采用各种数据库(如 Qracle.SQL Server.MySQL等)来实现对数据的存储.查询等功能.下面讲解如何在 Qt 中操作 SQlite 数据库. 一.SQLite 介绍 Sql ...
- 房租管理小软件(四):对linq的使用
1.对LInq的封装如下: private static System.Data.Linq.Mapping.MappingSource mappingSource = new AttributeMap ...
- Linux QT 连接 Sqlite数据库
#include <QApplication> #include <QDebug> #include <QSqlQuery> #include <QSqlDa ...
- 房租管理小软件(七):flowlayoutPancel 中增加分类控
见下图的 string FNodeName = dt.Rows[i]["FNodeName"].ToString(); ) { RoomControl.Thumbnail.Grou ...
- 房租管理小软件(六):通用功能包括时间,效验,MD5加密,XML 操作
1.时间相关 public static DateTime getNow() { MyFZDataContext dataContext = MyFZDataContext.getDataContex ...
- SQLite数据库基本操作
SQLite 是一个开源的嵌入式关系数据库,实现自包容.零配置.支持事务的SQL数据库引擎. 其特点是高度便携.使用方便.结构紧凑.高效.可靠. 与其他数据库管理系统不同,SQLite 的安装和运行非 ...
- SQLite数据库多平台应用及常见错误分析
SQLite是一个软件库,实现了自给自足的.无服务器的.零配置的.事务性的SQL数据库引擎.SQLite是世界上最广泛部署的数据库引擎之一.SQLite源代码开放,没有授权限制.正是因为其免费.轻巧. ...
- SQLite数据库下载、安装和学习
SQLite 是一个开源的嵌入式关系数据库,实现自包容.零配置.支持事务的SQL数据库引擎. 其特点是高度便携.使用方便.结构紧凑.高效.可靠.与其他数据库管理系统不同,SQLite 的安装和运行非常 ...
- Android SQLite数据库
SQLite数据库 SQLiteDatabase //管理操作数据库 管理 openDatabase //打开 openOrCreateDatabase //打开或创建 操作 ...
随机推荐
- UVALive 6255:Kingdoms(状压DFS)
题目链接 题意 给出n个王国和n*n的矩阵,mp[i][j] 代表第 i 个王国欠第 j 个王国 mp[i][j] 块钱.如果当前的王国处于负债状态,那么这个王国就会被消除,和它相连的王国的债务都会被 ...
- django基础知识之HttpReqeust对象:
HttpReqeust对象 服务器接收到http协议的请求后,会根据报文创建HttpRequest对象 视图函数的第一个参数是HttpRequest对象 在django.http模块中定义了HttpR ...
- ElasticStack学习(六):ElasticSearch搜索初探
一.ElasticSearch搜索介绍 1.ElasticSearch搜索方式主要分为以下两种: 1).URI Search:此种查询主要是使用Http的Get方法,在URL中使用查询参数进行查询: ...
- WebSocket+Netty构建web聊天程序
WebSocket 传统的浏览器和服务器之间的交互模式是基于请求/响应的模式,虽然可以使用js发送定时任务让浏览器在服务器中拉取但是弊端很明显,首先就是不等避免的延迟,其次就是频繁的请求,让服务器的压 ...
- [MySQL]快速解决"Table '.\sjzlf\zbp_post' is marked as crashed and should be repaired"故障
为了不冒失修复,故采取保守做法,我们知道 MySQL 一个高效的管理工具便是 PhpMyAdmin,而在该管理软件中就包含了对表的检查.分析.修复.优化功能,比起网上提供的含糊命令行来说更安全更简便. ...
- kubernetes安装部署-day01
一.基础环境的准备: 1.1.安装docker: docker的官网是:https://www.docker.com/ 1.1.1.rpm包安装: 官方下载地址:https://download.do ...
- CDQZ集训DAY5 日记
又一个爆炸的一天…… 早上起来发现貌似是周末,七中放假(别人家的学校(一周一放,一放两天)……)然而感觉状态不是很好,感觉药丸. 题目一上来就装弱,有诈.第一题上来先打暴力,T2不知道怎么打.T3暴力 ...
- Python用法
Python用法 IDE IDE是集成开发环境:Integrated Development Environment的缩写. 使用IDE的好处在于按,可以把编写代码.组织项目.编译.运行.调试等放到一 ...
- VMware里装XP 没有找到硬盘驱动器
遇到问题: 解决:要给虚拟机配上一个虚拟的硬盘驱动器.在VMWare的虚拟机配置里面给这个虚拟机增加硬盘,选IDE模式,而非SCSI,设定硬盘大小和文件名就可以了.
- Java中注释的使用
Java 中注释有三种类型:单行注释.多行注释.文档注释 我们可以通过 javadoc 命令从文档注释(/**aa*/)中提取内容,生成程序的 API 帮助文档. 打开首页,查看下生成的 API 文档 ...