免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2781 | 回复: 2
打印 上一主题 下一主题

CU上大神挺多,贴几段代码给大神们评审一下 [复制链接]

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 10:01:44
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-06-30 18:54 |只看该作者 |倒序浏览
CU上大神挺多,贴几段代码给大神们评审一下。
因为大神们见多识广,目的就是把这几段虽然简单,但是却很基础、使用很频繁的代码给优化到极致,性能达到最好:
第一段:一个数据库操作封装,目的就是一个方法完成所有数据库相关的操作。

  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-


  3. import mysql.connector
  4. import mysql.connector.pooling
  5. import mysql.connector.cursor


  6. class Db(object):

  7.     def __init__(self, config, pool_name=None, pool_size=5):
  8.         self.pool = mysql.connector.pooling.MySQLConnectionPool(
  9.             pool_name=pool_name,
  10.             pool_size=pool_size,
  11.             **config)

  12.     def get_connection(self):
  13.         return self.pool.get_connection()

  14.     def execute(self, sql, params=None):
  15.         conn = self.get_connection()
  16.         cursor = conn.cursor(buffered=True, cursor_class=MySQLDictCursor)
  17.         data_set = []
  18.         for result in cursor.execute(sql, params, multi=True):
  19.             if result.with_rows:
  20.                 data_set.append(result.fetchall())
  21.             else:
  22.                 data_set.append(None)
  23.         conn.commit()
  24.         cursor.close()
  25.         conn.close()
  26.         return data_set


  27. class MySQLDictCursor(mysql.connector.cursor.MySQLCursor):

  28.     def _row_to_python(self, row_data, desc=None):
  29.         row = super(MySQLDictCursor, self)._row_to_python(row_data, desc)
  30.         if row:
  31.             return dict(zip(self.column_names, row))
  32.         return None
复制代码

求职 : 系统工程师等
论坛徽章:
5
技术图书徽章
日期:2014-04-19 22:01:05天蝎座
日期:2014-05-09 13:49:28双子座
日期:2014-06-16 15:08:042015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:55:28
2 [报告]
发表于 2014-06-30 21:33 |只看该作者
我是来学习的!

论坛徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午马
日期:2014-08-06 03:56:58
3 [报告]
发表于 2014-07-01 15:42 |只看该作者
发觉代码给优化到极致了啊。
学习。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP