设为首页 收藏本站
查看: 756|回复: 0

[经验分享] mysql八:ORM框架SQLAlchemy

[复制链接]

尚未签到

发表于 2018-10-6 06:33:47 | 显示全部楼层 |阅读模式
  一、介绍
  SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据API执行SQL并获取执行结果。
  1、安装
  pip3 install sqlalchemy
  2、架构与流程
DSC0000.jpg

  第一步:使用者通过ORM对象提交命令
  第二步:将命令交给SQLAlchemy Core(Schema/Types  SQL Expression Language)转换成SQL
  第三步:使用 Engine/ConnectionPooling/Dialect 进行数据库操作
  1)匹配使用者事先配置好的egine
  2)egine从连接池中取出一个链接
  3)基于该链接通过Dialect调用DB API,将SQL转交给它去执行
  上述流程分析,可以大致分为两个阶段:
  第一个阶段(流程1-2):将SQLAlchemy的对象换成可执行的sql语句
  第二个阶段(流程3):将sql语句交给数据库执行
  如果我们不依赖于SQLAlchemy的转换而自己写好sql语句,那意味着可以直接从第二个阶段开始执行了;我们完全可以只用SQLAlchemy执行纯sql语句,代码如下:
  from sqlalchemy import create_engine
  #1、准备
  #需要事先安装好pymysql
  #需要事先创建好数据库:create database db1 charset utf8;
  #2、创建引擎
  egine=create_engine('mysql+pymysql://root@127.0.0.1/db1?')
  #3、执行sql
  egine.execute('create table if not EXISTS t1(id int PRIMARY KEY auto_increment,name char(32));')
  cur=egine.execute('insert into t1 values(%s,%s);',[(1,"egon1"),(2,"egon2"),(3,"egon3")]) #按位置传值
  cur=egine.execute('insert into t1 values(%(id)s,%(name)s);',name='egon4',id=4) #按关键字传值
  #4 新插入行的自增id
  print(cur.lastrowid)
  #5、查询
  cur=egine.execute('select * from t1')
  cur.fetchone() #获取一行
  cur.fetchmany(2) #获取多行
  cur.fetchall() #获取所有行
  3、DB API
  SQLAlchemy本身无法操作数据库,其必须以来pymsql等第三方插件,Dialect用于和数据API进行交流,根据配置文件的不同调用不同的数据库API,从而实现对数据库的操作,如:
  1)MySQL-Python
  mysql+mysqldb://:@[:]/
  2)pymysql
  mysql+pymysql://:@/[?]
  3)MySQL-Connector
  mysql+mysqlconnector://:@[:]/
  4)cx_Oracle
  oracle+cx_oracle://user:pass@host:port/dbname[?key=value&key=value...]
  二、创建表
  ORM中:
  类===>表
  对象==>表中的一行记录
  四张表:业务线,服务,用户,角色,利用ORM创建出它们,并建立好它们直接的关系
  三、增删改查
  表结构
  1、增
  2、删
  3、改
  4、查
  四、其他查询相关
  1、准备表和数据
  2、条件、通配符、limit、排序、分组、连表、组合
  3、子查询
  有三种形式的子查询,注意:子查询的sql必须用括号包起来,尤其在形式三中需要注意这一点
  形式一:子查询当做一张表来用,调用subquery()
  形式二:子查询当做in的范围用,调用in_
  形式三:子查询当做select后的字段,调用as_scalar()
  五、正查、反查
  1、表修改
  2、标准连表查询
  #示例:查询员工名与其部门名
  res=session.query(Emp.ename,Dep.dname).join(Dep) #迭代器
  for row in res:
  print(row[0],row[1]) #等同于print(row.ename,row.dname)
  3、基于relationship的正查、反查
  #SQLAlchemy的relationship在内部帮我们做好表的链接
  #查询员工名与其部门名(正向查)
  res=session.query(Emp)
  for row in res:
  print(row.ename,row.id,row.depart.dname)
  #查询部门名以及该部门下的员工(反向查)
  res=session.query(Dep)
  for row in res:
  # print(row.dname,row.xxoo)
  print(row.dname,[r.ename for r in row.xxoo])


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-612892-1-1.html 上篇帖子: MySQL第二天 下篇帖子: CentOS 7 LNMP部署—mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表