百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

「Python系列」Flask项目实战十二之ORM框架的原理(三)

ccwgpt 2025-03-26 10:16 57 浏览 0 评论

4. 进阶的orm方式,表与字段不固定

#第一部分,使用非orm的模式设计数据库表操作
import pymysql
from pymysql.cursors import DictCursor

class MySQL:
    #初始化并实例创建数据库连接
    def __init__(self):
        #创建数据库连接
        conn =pymysql.connect(host='127.0.0.1', user='root', password='root', charset='utf8', database='zentao', autocommit=True)
        #创建游标,并定义可以获取游标的字段名
        self.cursor = conn.cursor(DictCursor)

    #定义查询方法
    def query(self,sql):
        #执行sql语句
        self.cursor.execute(sql)
        result = self.cursor.fetchall()
        return result

    #定义修改操作方法
    def my_update(self, sql):
        try:
            self.cursor.execute(sql)
            return 'OK'
        except:
            return "Fail"


#封装成标准的模型类,提供子类继承
#数据库方面不指定明确的表名
#增加一个field()方法来指定查询哪些列,*代表所有列
class Model:
    ##构造方法,自动化列表转为Key,value的对应关系
    def __init__(self, **kwargs):
        for k, v in kwargs.items():
            self.__setattr__(k, v)

   #通过链接操作的最后返回必定指向自己如:return self ,指定查询哪些字段,让查询的字段不在语句内固定
    def field(self, columns):
       self.columns = columns
       return self

    #重新封装查询方法,让表名与字段名不固定
    def select(self, **where):
        #获取继承的子类传进来的表名,此处的self为子类的类名
        table = self.__class__.__getattribute__(self, "table_name")

        #判断对象是否包含对应的属性,即传入的对象columns属性
        if hasattr(self, "columns"):
            sql = "select %s from %s" % (self.columns, table)
        else:
            sql = "select * from %s" % table
        # 取出where字典参数的内容,使用None判断列否为空,即使where无值也是非空,只有采用判断len(where)!=0才能真正判断是否空值
        # if where is not None:
        if len(where) != 0:
            sql += " where"
            for k, v in where.items():
                sql += " %s=%s and" % (k, v)
            sql += " 1=1"

        # 增加条件输入的查询操作
        result = MySQL().query(sql)
        return result

            # 封装新增

    def insert(self):
        # 构造函数取出来的字典后,在Insert时需要把key 与 value分开为两个列表,分别对应插入语法的两个部分
        keys = []
        values = []
        for k, v in self.__dict__.items():
            keys.append(k)
            values.append(str(v))

        # 使用join将连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串
        sql = "insert into %s(%s) value('%s')" % (self.table_name, ",".join(keys), "','".join(values))
        result = MySQL().query(sql)
        return result

#子类继承于父类
class Users(Model):
    table_name = 'zt_build'

    #通过子类的构造函数,调用父类的构造函数
    def __init__(self, **kwargs):
        super().__init__(**kwargs)


if __name__ == '__main__':
    user = Users()
    #查询所有记录
    # result = user.select()
   #查询指定字段的内容
    result = user.field('id, project, name').select(id = 1)
    print(result)

相关推荐

公司组织架构及部门职责#管理制度 #薪酬绩效 #组织架构

...

终于把“公司组织架构与管理部岗位配置”整理好了,拿来即用!

...

老板看完这份“公司组织架构详解”就解放了!

...

丨公司丨公司大架构整理汇总

注:本文转自团队成员原创作品,特此鸣谢(公号:法海图鉴)今日话题公司大架构整理背景介绍经过前几期话题对各种企业类型的介绍,想必大家已经有了初步认识。之后我将带着大家开启对公司的深入了解。本期...

图解物理--八年级物理下册最全知识框架导图

第七章力1力2弹力3重力第八章运动和力1牛顿第一定律2二力平衡3摩擦力第九章压强1压强2液体压强3大气压强4流体压强与流速的关系第十章浮力1浮力2阿基米德原理3物体的浮沉条件及应用第十一章功...

八年级上册生物,思维导图,期末高分必备资料,家长收藏

这是八年级上册生物的思维导图,孩子在背诵知识点的时候,可以看一下知识点在导图中的位置,形成对知识点整体的把握,有助于学生拿高分,特别是图片中带红色星星的部分,更是要注意背诵,是重点内容。家长可以把图片...

2019政府工作报告精华,这张思维导图里全都有

每经记者:李可愚每经编辑:陈星每日经济新闻

图解薪酬体系结构设计

...

司考复习独家总结!一张图总结行政法知识结构体系

作为三大实体法之一,行政法的分值在60分左右,行政法在司法考试中一直比较平稳常规,没有偏题怪题,还是比较容易得分的。小编要提醒大家,在3月之前要把三大实体法学习一遍。下图是厚大在线360导学师小周总结...

一图读懂香港国安新架构:各职位人选公布 有官员曾强硬喊话乱港分子

实用干货!高中物理框架图,让零碎知识“串联”起来

高中物理学习一定要抓好逻辑结构大框架!了解整个知识框架体系后,更易抓住骨干知识,干掉重难知识点~今天给大家分享高中物理的框架图同学们赶紧收藏起来吧!力学知识结构图光学知识结构图热学、原子物理知识结构图...

254m超高层办公楼型钢砼框架-核心筒结构图

高度类别:超高层建筑钢筋混凝土结构:框架,框架核心筒钢结构:钢框架建筑功能:办公包含:办公楼57层(-3层)254.150m钻孔灌注桩桩+筏板型钢混凝土框架-钢筋混凝土核心筒西裙房2层(-...

砖混结构与框架结构,究竟有何区别?千万别被坑!

现在买房装修的人最怕啥?不是价格高,而是房子不安全!两种主流建筑结构,砖混靠墙,框架靠柱子,选错了隔墙都可能要命。简单说,砖混便宜但别碰高层,框架贵点但能保命。砖混那些承重墙根本不能拆,想砸墙改个开放...

大师一百——高中化学必考:《元素周期律》考点框架图

今天大师给大家带来的是高中化学的《元素周期律》考点框架图,高中的同学必须牢记于心,这种重要的考点,考试是一定会考的!化学大师...

需求分析框架图

需求分析框架图

取消回复欢迎 发表评论: