python_mysql封装及思路详解

随着需要入库的数据越来越多,这样相应的sql操作越来越多;
正好在做单元测试的时候看见laravel中对库操作的封装思想,用过感觉逻辑性很强,索性拿过来;

基础:

FOR Python2.7
import MySQLdb
import MySQLdb.cursors

封装思想:

  • 封装Base类,即父类
  • 封装操作表(Table)类,即子类
  • Table类继承Base类,且在Table类中只操作当前表,也就是说每个表对应一个Table类
  • Table类类名称的命名规则:类名即表名,保持一致,这样可以通过获取当前类名称达到获取表名的目的;

具体实现:

Base.py

  • 定义父类Base
  • 完成连接数据库操作,并获取游标cursor
  • 封装最基础表操作:增删改查及公共方法
一览表
class Base:
    """    
    mysql相关方法
    connect:链接数据库
    creat_table:创建表
    create datebase dbname;
    """
    def __init__(self):
        """   
        链接数据库
        :param kwargs:
        """
        self.db, self.cursor =self.__connect()
    def __connect(self, database='', who='Null'):
        """链接数据库"""
        ip, username, password, database = self.__getConnectData(database, who)#此方法为的读取配置文件的封装方法
        try:
            self.db = MySQLdb.connect(
                ip, username, password, database, charset='utf8',
                 cursorclass=MySQLdb.cursors.DictCursor) 
            return self.db, self.db.cursor()
        except MySQLdb.Error as msg:
            raise msg
    def __sql_contact(self, **kwargs):
    """
    构造和拼接sql语句
    :param data: 查询字段
    :param table: 表名
    :param where: 条件
    :param limit: 返回条数
    :param order: 排序
    :param group: 分组
    :return:
    """
      data = ''
      table = ''
      where = ''
      limit = ''
      order = ''
      group = ''
      if kwargs:
        for key, value in kwargs.items():
            if key =='data':
                data = str(value)
            if key =='table':
                table = str(value)
            if key =='where':
                where = str(value)
            if key =='limit':
                limit = str(value) 
            if key =='order':
                order = str(value)
            if key =='group':
                group = str(value)
      where = ' WHERE ' + where if where else ''
      limit = ' LIMIT ' + limit if limit else ''
      order = ' ORDER BY ' + order if order else '' 
      group = ' GROUP BY ' + group if group else '' 
      data = data if data else '*'
      sql = 'SELECT ' + data + ' FROM ' + table + where + group + order + limit  
      return sql
   def query(self, sql):
    """
    查询表,且带上字段名称
    :param
    :param sql:输出查询语句
    :return:返回字典
    """
    try: 
        cur = self.cursor
        cur.execute(sql)
        index = cur.description
        result = []
        response = cur.fetchall()
        if response:
            for res in response:
                row = {}
                for i in range(len(index)):
                    row[index[i][0]] = res[index[i][0]]
                result.append(row)
            return result
        else:
            return {'status': '0', 'msg': 'result is Null'}
    except Exception as msg:
        print (msg)
        raise
  def select(self, **kwargs):
    """
    查询表
    :param data: 查询字段
    :param table: 表名
    :param where: 条件
    :param limit: 返回条数
    :param order: 排序
    :param group: 分组
    :return: 查询结果
    """
    sql = self.__sql_contact(**kwargs)
    result = self.query(sql)
    return result
  ......

Table类中todo.py

  • 继承Base类
  • 获取表名
  • 重写父类中方法
# coding=utf-8
__author__ = 'xcma'
import os
import sys
from Src.Function.Base import Base
class todo(Base):
    def __init__(self):
        Base.__init__(self)
        self.table = self.__getTableName()
    def __getTableName(self):
        """
        返回当前文件的名称、文件名及路径
        :param is_path:
        :return:
        """
        return os.path.basename(__file__).split('.')[0]
    def select_todo(self, data='', where='', limit='', order='', group=''):
        kwargs = dict(data=data, table=self.table, where=where, limit=limit, order=order, group=group)
        result = Base.select(self, **kwargs)
        return result

注意:**kwargs的使用尽量放在内部调用时使用,暴露在最外层的接口最好将必填参数全部暴露出来,这样在外部调用的时候参数显而易见,在内部调用看起来很简洁;而且配置可变参数会更加灵活些;

总结:

  • mysql类这样封装完以后,业务上需要操作哪个表,就直接引用哪个表文件即可,丝毫不用担心表名是什么;
  • 如果某个操作很常见,则可以提到Base类中,这样对各个表中的复用、重写会很方便;

@雾霾 -2016-12-16 22:01:09

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容