Python中第三方库封装mysql数据库的示例分析
admin
2023-06-27 04:23:18
0

  这次封装数据库,就算不是为了自动化测试,数据库操作也必须要会,为什么?因为在很多时候,修复现网用户数据都是通过脚本实现的,如果不用其他语言,那么python在这一块的优势就十分明显了。

  '''

  Created on 2019年10月10日

  @author: qguan

  '''

  import pymysql

  from utils.HandleLogging import log as logging

  mysql_info = {"host": '127.0.0.1',

  "port": 3306,

  "user": 'root',

  "passwd": 'root',

  "db": 'mysql',

  "charset": 'utf8'}

  class HandleMySQL(object):

  '''

  classdocs

  '''

  def __init__(self):

  '''

  初始化mysql数据库信息,创建连接游标

  '''

  self.db_info = mysql_info

  self.logger = logging

  try:

  self.conn = pymysql.connect(host=self.db_info['host'],

  port=self.db_info['port'],

  user=self.db_info['user'],

  passwd=self.db_info['passwd'],

  db=self.db_info['db'],

  charset=self.db_info['charset'],

  cursorclass=pymysql.cursors.DictCursor)

  self.logger.info("success!")

  except Exception as a:

  self.logger.info("failture:%s" % a)

  raise a

  else:

  self.logger.info("create cursor!")

  self.cursor = self.conn.cursor()

  def __call__(self, sql, arg=None, is_more=False):

  '''

  调用数据库执行方法

  :param sql:执行的sql语句,str类型

  :param arg:参数必须是序列类型:list、str、tuple

  :param is_more:是否查询显示更多数据,通常根据sql的limit来确定

  :return:

  '''

  self.mysql_execute(sql, arg)

  if is_more:

  result = self.cursor.fetchall()

  else:

  result = self.cursor.fetchone()

  # 不合适,如果还有sql在循环执行,在这里关闭,会造成sql执行失败

  # self.mysql_close()

  return result

  def mysql_execute(self, sql, arg=None):

  '''郑州人流医院哪家好 http://mobile.zhongyuan120.com/

  封装自己执行sql语句的方法

  '''

  try:

  self.cursor.execute(sql)

  except Exception as a:

  self.conn.rollback() # sql回滚处理

  self.logger.info("回滚sql,异常如下:{}".format(a))

  raise a

  else:

  self.conn.commit() # sql提交

  def mysql_getrows(self, sql):

  '''

  返回查询结果集

  :return: 返回的是一个嵌套字典的元组

  '''

  try:

  self.cursor.execute(sql) # arg必须是序列类型

  except Exception as a:

  self.logger.info("执行SQL语句出现异常:%s" % a)

  raise a # 直接抛出异常,不在执行后面的语句

  else:

  rows = self.cursor.fetchall()

  return rows

  def mysql_getrow(self, sql):

  '''

  返回查询结果集

  return:结果是个字典

  '''

  try:

  self.cursor.execute(sql) # arg必须是序列类型

  except Exception as a:

  self.logger.info("执行SQL语句出现异常:%s" % a)

  raise a

  else:

  row = self.cursor.fetchone()

  return row

  def mysql_close(self):

  '''

  关闭数据库连接,关闭游标

  '''

  try:

  self.conn.close()

  self.cursor.close()

  self.logger.info("正常关闭mysql连接!")

  except Exception as a:

  self.logger.info("关闭mysql连接池失败,异常如下:{}".format(a))

  raise a

  if __name__ == '__main__':

  mq = HandleMySQL()

  sql = 'SELECT *from user limit 3'

  # print(mq(sql, is_more=True))

  mq.mysql_close()

相关内容

热门资讯

俄军已控制七成城区,乌东重镇或... 据凤凰卫视报道,乌克兰武装部队在康斯坦丁诺夫卡市的处境正进一步恶化。根据几个隶属于乌军的社交媒体账号...
人民日报:AI一本正经胡说八道... 日前,江苏一顾客用AI软件预约餐厅,到店后却被告知无预约记录,怒写差评,商家称不支持AI订座,AI软...
燃气灶开关怎么维修 燃气灶是我们日常生活中经常使用的一种电器,而灶具的开关是其功能的核心部分之一,一旦发生故障,可能会影...
燃气灶看不见火花怎么办 如果燃气灶看不见火花,可能是因为以下原因:1. 火花塞头脏了:为了确保正常工作,燃气灶上的火花塞头需...
燃气灶靠墙吧台收纳方法 燃气灶靠墙吧台是很多小型家庭厨房常见的布局,因为这种布局既方便省空间,又能满足日常烹饪需要。但是由于...
燃气灶孔不着火怎么办 燃气灶是现在生活中常见的一种厨房生活用具,能够高效地加速烹饪和煮食的速度。但有时候,我们在使用燃气灶...
燃气灶孔除锈方法 燃气灶是我们厨房中非常重要的设备,其功能强大,且使用方便,可是经常使用燃气灶会造成灶具孔的锈蚀与污垢...
iPhone18Pro无缘钛金... 5月30日消息,此前有行业爆料称,苹果内部正积极研发改良版钛金属材料,计划在后续迭代的旗舰机型中弃用...
走进实验室玩转科学 各地以科普... 央视网消息:今天(5月30日)是第十个全国科技工作者日。连日来,各地科技部门、现代科技馆体系组织系列...
俄外交部称已召回驻亚美尼亚大使 当地时间5月30日,俄罗斯外交部发布消息称,因亚美尼亚领导层加速与欧盟靠拢,俄方已召回驻亚美尼亚大使...