Mysql多实例
一、mysql多实例介绍1.1概念mysql多实例就是在一台物理主机上运行多个数据库服务1.2作用节约运维成本,提高硬件利用率1.3 原理通过安装支持mysql多实例的软件包,实现在一台机器上开启多个...
2024.11.12其中,sql_config.cfg文件内容为:
若不用配置文件,直接把5个参数写在程序里也可以,代码如下,貌似更简单:
class MysqlDb():def __init__(self):self.conn = pymysql.connect(host=‘127.0.0.1’,port=3306,user=‘root’,passwd=‘771222’,db=‘1’)self.cur = self.conn.cursor(cursor=pymysql.cursors.DictCursor)一、显示数据库内容功能:在软件界面,点击左侧导航栏,找到数据库中与展开项对应的表,将数据显示在中间表格里。若目标表不存在,提示创建。
实现步骤:
创建导航栏; 点击导航栏,获取表名; 查询数据库,找到表,显示内容
具体过程:
1、用树形控件创建导航栏,数据来源为数据库
数据库里导航栏数据源样式为:
用代码手动逐条输入是不可接受的,根据第一列数据长度特点,采用下面的批量创建方式,其中fl为传递的参数,意思是“路基”或者其他专业。
def set_tree(self, fl):qd_lj = MysqlDb().select_db(‘select * FROM 清单‘ + fl)# 通过自建的Mysqlbd类的select_db函数,得到数据库里的目标表root = QTreeWidgetItem(self.tree)root.setText(0, fl)root.setIcon(0, QIcon(r‘source\3.png‘))for i in range(0, len(qd_lj)):bm = qd_lj[i][‘编码‘]mc = qd_lj[i][‘名称‘]if (len(bm) == 4):root1 = QTreeWidgetItem(root)root1.setText(0, mc)root1.setText(1, bm)elif (len(bm) == 7):root2 = QTreeWidgetItem(root1)root2.setText(0, mc)root2.setText(1, bm)elif (len(bm) == 10):root3 = QTreeWidgetItem(root2)root3.setText(0, mc)root3.setText(1, bm)elif (len(bm) == 13):root4 = QTreeWidgetItem(root3)root4.setText(0, mc)root4.setText(1, bm)elif (len(bm) == 16):root5 = QTreeWidgetItem(root4)root5.setText(0, mc)root5.setText(1, bm)elif (len(bm) == 19):root6 = QTreeWidgetItem(root5)root6.setText(0, mc)root6.setText(1, bm)elif (len(bm) == 22):root7 = QTreeWidgetItem(root6)root7.setText(0, mc)root7.setText(1, bm)else:passself.tree.expandAll()# 设置树形构件全部展开self.item = root# 自定义设置初始选中根条目2、设置点击树形控件条目的信号槽函数,将数据库表内容提取后显示在表格控件。
self.tree.itemClicked.connect(self.showtreesql)设置左键单击导航栏时,触发函数showtreesql()。具体获取数据功能在函数里设置。
def showtreesql(self, item):# 单击树形节点,将数据库内容显示在表里self.inputtable.clearContents()#清空中间的表格控件self.inputtable.setRowCount(0)# 初始表格控件self.item = item# 单击导航栏时,信号槽自动带当前点击节点信息参数itemif not item.child(0):# 判断如果该节点没有子节点,即单击的为最底层节点,非子节点无对应表格self.decxcomb3.setDisabled(False)self.select_item = "n" + item.text(1).replace(‘-‘, ‘‘)# 根据该节点编码,得到对应表格名称if self.decxcomb3.findText(self.select_item) == -1:self.decxcomb3.addItem(self.select_item)self.decxcomb3.setCurrentText(self.select_item)# 将表格名称显示在下拉框控件里if self.table_exists(MysqlDb(), self.select_item):# 查询数据库,判断是否存在对应的表,self.inputtable.setRowCount(1)self.sql_to_input(self.select_item, self.inputtable)#如果存在表,查询数据库,将数据读取到表格else:# self.decxcomb3.isEnabled()self.decxcomb3.setDisabled(True)3、读取数据库内容到表格的功能函数代码:
def sql_to_input(self, sql_tabel, inputtable):data = MysqlDb().select_db(‘select * FROM ‘ + sql_tabel)if data:inputtable.setRowCount(len(data))for i in range(len(data)):inputtable.setItem(i, 0, QTableWidgetItem(data[i][‘定额编号‘]))inputtable.setItem(i, 1, QTableWidgetItem(data[i][‘定额名称‘]))inputtable.setItem(i, 2, QTableWidgetItem(data[i][‘单位‘]))inputtable.setItem(i, 3, QTableWidgetItem(data[i][‘数量‘]))#print(‘数据库写入已完成”‘)else:#print(‘源表为空表,不执行写入操作‘)pass判断数据库是否存在某表的函数块:
def table_exists(self, sql, table_name):# 这个函数用来判断数据库是否含某表tables = sql.select_db(‘SHOW TABLES‘)# 得到数据库里的所有表名,tabels_list = []for i in tables:n = i[‘Tables_in_1‘]tabels_list.append(n)if table_name in tabels_list:return 1else:return 04、左键双击导航栏时,触发信号槽,当不存在目标表时,提示创建新表:
def edittreesql(self, item):# 双击树形节点,将新建数据库表if not item.child(0):# 判断该节点没有子节点self.select_item = "n" + item.text(1).replace(‘-‘, ‘‘)# 记录该节点编码self.decxcomb3.addItem(self.select_item)self.decxcomb3.setCurrentText(self.select_item)if self.table_exists(MysqlDb(), self.select_item):# 判断是否存在本节点为名的表# 判断结果存在,将内容显示在表格控件里self.inputtable.clearContents()self.sql_to_input(self.select_item, self.inputtable)else:if QMessageBox.information(self, "创建定额表","即将为本清单创建定额输入表:" + self.select_item,QMessageBox.Yes | QMessageBox.No) == QMessageBox.Yes:MysqlDb().biuldtabel(self.select_item)# 若没有则在数据库新建一个表,self.inputtable.clearContents()self.inputtable.setRowCount(1)print(‘已创建表:‘, self.select_item)二、修改数据库内容1、设置保存按钮
self.saveinput = QPushButton(‘保存到数据库‘)self.saveinput.clicked.connect(self.input_to_sql)2、编写保存按钮点击函数块
def input_to_sql(self):if self.decxcomb3.currentText():MysqlDb().execute_db(‘delete FROM ‘ + self.decxcomb3.currentText())# 写入数据库前先清空原内容for i in range(self.inputtable.rowCount()):v = []for j in range(4):if self.inputtable.item(i, j):v.append(self.inputtable.item(i, j).text())else:v.append(‘‘)insert_sql = ‘insert INTO ‘ + self.decxcomb3.currentText() + " (定额编号, 定额名称, 单位, 数量) VALUES(‘" + v[0] + "‘, ‘" + v[1] + "‘, ‘" + v[2] + "‘, ‘" + v[3] + "‘)"MysqlDb().execute_db(insert_sql)三、表格控件指定滑块位置设置下拉框选择项目后,根据项目名让中间下部的表格上下滑块移动至将当前项目显示在第一位:
设置信号槽:self.decxcomb2.currentTextChanged[str].connect(self.set_table2)
设置功能块代码:
def set_table2(self, fl):for i in range(self.table2.rowCount()):if self.table2.item(i, 0).text() == fl:breakself.table2.verticalScrollBar().setValue(i)四、自定义右键菜单表格输入时,有时候难免存在需要插入行、删除行的要求,最常见的就是下面的右键菜单处理了。
实现过程:
1)设置表格控件能响应右键
self.inputtable.setContextMenuPolicy(Qt.CustomContextMenu)2)设置右键信号槽函数
self.inputtable.customContextMenuRequested.connect(self.input_rightmenu)def input_rightmenu(self):# 指定定额输入表控件右键菜单try:self.contextMenu = QMenu()self.actionA = self.contextMenu.addAction(u‘删除‘)self.actionB = self.contextMenu.addAction(u‘插入‘)self.actionA.setIcon(QIcon(r"source\4.png"))self.contextMenu.popup(QCursor.pos())# 菜单显示的位置self.actionA.triggered.connect(self.deletcurrow)self.actionB.triggered.connect(self.insertcurrow)self.contextMenu.show()except Exception as e:print(e)3)函数功能块设置
def deletcurrow(self):self.inputtable.removeRow(self.inputtable.currentRow())# 删除当前行def insertcurrow(self):self.inputtable.insertRow(self.inputtable.currentRow()) #在当前行插入一行一、mysql多实例介绍1.1概念mysql多实例就是在一台物理主机上运行多个数据库服务1.2作用节约运维成本,提高硬件利用率1.3 原理通过安装支持mysql多实例的软件包,实现在一台机器上开启多个...
2024.11.12简单数据查询操作增删改查是数据表操作的重要组成部分,尤其是数据表的查询更是数据库与各类应用交互的频繁操作之一。本文课主要介绍简单数据查询语句。查询语句基本语法查询语句是实现数据查询的SQL语句,用于实...
2024.11.12一、MySQL简介MySQL一般特制完整的MySQLRDBMS,是一个开源的关系型数据库管理系统(Relational Database Management System),现在属于Oracle公司...
2024.11.12假设用户表有一百万用户量。也就是1000000.num是主键1:对查询进行优化,应尽量避免全表扫描,首先应考虑在where及order by涉及的列上创建索引。因为:索引对查询的速度有着至关重要的影响...
2024.11.14当数据库服务器数量有限时,为了有效利用单台服务器资源,在服务器资源有剩余时,可以充分利用剩余的资源提供更多的服务。单台服务器部署多个MySQL实例,这里以MySQL5.7为例,部署步骤如下:1、 下载...
2024.11.13