Python操作MySQL之SQLAlchemy

原文:https://www.cnblogs.com/ccorz/p/5711955.html

SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据API执行SQL并获取执行结果。

SQLAlchemy本身无法操作数据库,其必须以来pymsql等第三方插件,Dialect用于和数据API进行交流,根据配置文件的不同调用不同的数据库API,从而实现对数据库的操作.

MySQL-Pythonmysql+mysqldb://<user>:<password>@<host>[:<port>]/<dbname>pymysqlmysql+pymysql://<username>:<password>@<host>/<dbname>[?<options>]MySQL-Connectormysql+mysqlconnector://<user>:<password>@<host>[:<port>]/<dbname>cx_Oracleoracle+cx_oracle://user:pass@host:port/dbname[?key=value&key=value...]更多详见:http://docs.sqlalchemy.org/en/latest/dialects/index.html

底层处理

使用 Engine/ConnectionPooling/Dialect 进行数据库操作,Engine使用ConnectionPooling连接数据库,然后再通过Dialect执行SQL语句。

#!/usr/bin/env python
# -*- coding:utf-8 -*-
from sqlalchemy import create_engineengine = create_engine("mysql+pymysql://root:123@127.0.0.1:3306/t1", max_overflow=5)# 执行SQL
# cur = engine.execute(
#     "INSERT INTO hosts (host, color_id) VALUES ('1.1.1.22', 3)"
# )# 新插入行自增ID
# cur.lastrowid# 执行SQL
# cur = engine.execute(
#     "INSERT INTO hosts (host, color_id) VALUES(%s, %s)",[('1.1.1.22', 3),('1.1.1.221', 3),]
# )# 执行SQL
# cur = engine.execute(
#     "INSERT INTO hosts (host, color_id) VALUES (%(host)s, %(color_id)s)",
#     host='1.1.1.99', color_id=3
# )# 执行SQL
# cur = engine.execute('select * from hosts')
# 获取第一行数据
# cur.fetchone()
# 获取第n行数据
# cur.fetchmany(3)
# 获取所有数据
# cur.fetchall()

说白了就是使用pymysql的方法一样.

ORM功能使用

创建表

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String, ForeignKey, UniqueConstraint, Index
from sqlalchemy.orm import sessionmaker, relationship
from sqlalchemy import create_engineengine = create_engine("mysql+pymysql://root:7ujm8ik,@192.168.4.193:3306/testsql", max_overflow=5)Base = declarative_base()# 创建单表
class Users(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)name = Column(String(32))extra = Column(String(16))__table_args__ = (UniqueConstraint('id', 'name', name='uix_id_name'),Index('ix_id_name', 'name', 'extra'),)# 一对多
class Favor(Base):__tablename__ = 'favor'nid = Column(Integer, primary_key=True)caption = Column(String(50), default='red', unique=True)class Person(Base):__tablename__ = 'person'nid = Column(Integer, primary_key=True)name = Column(String(32), index=True, nullable=True)favor_id = Column(Integer, ForeignKey("favor.nid"))# 多对多
class ServerToGroup(Base):__tablename__ = 'servertogroup'nid = Column(Integer, primary_key=True, autoincrement=True)server_id = Column(Integer, ForeignKey('server.id'))group_id = Column(Integer, ForeignKey('group.id'))class Group(Base):__tablename__ = 'group'id = Column(Integer, primary_key=True)name = Column(String(64), unique=True, nullable=False)class Server(Base):__tablename__ = 'server'id = Column(Integer, primary_key=True, autoincrement=True)hostname = Column(String(64), unique=True, nullable=False)port = Column(Integer, default=22)#定义初始化数据库函数
def init_db():Base.metadata.create_all(engine)#顶固删除数据库函数
def drop_db():Base.metadata.drop_all(engine)# drop_db()
init_db()

操作表

操作后我们会发现,class定义的为首字母大写,写入表以后为全部小写的模式.

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String, ForeignKey, UniqueConstraint, Index
from sqlalchemy.orm import sessionmaker, relationship
from sqlalchemy import create_engineengine = create_engine("mysql+pymysql://root:7ujm8ik,@192.168.4.193:3306/testsql", max_overflow=5)Base = declarative_base()# 创建单表
class Users(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)name = Column(String(32))extra = Column(String(16))__table_args__ = (UniqueConstraint('id', 'name', name='uix_id_name'),Index('ix_id_name', 'name', 'extra'),)# 一对多
class Favor(Base):__tablename__ = 'favor'nid = Column(Integer, primary_key=True)caption = Column(String(50), default='red', unique=True)class Person(Base):__tablename__ = 'person'nid = Column(Integer, primary_key=True)name = Column(String(32), index=True, nullable=True)favor_id = Column(Integer, ForeignKey("favor.nid"))# 多对多
class ServerToGroup(Base):__tablename__ = 'servertogroup'nid = Column(Integer, primary_key=True, autoincrement=True)server_id = Column(Integer, ForeignKey('server.id'))group_id = Column(Integer, ForeignKey('group.id'))class Group(Base):__tablename__ = 'group'id = Column(Integer, primary_key=True)name = Column(String(64), unique=True, nullable=False)class Server(Base):__tablename__ = 'server'id = Column(Integer, primary_key=True, autoincrement=True)hostname = Column(String(64), unique=True, nullable=False)port = Column(Integer, default=22)#定义初始化数据库函数
def init_db():Base.metadata.create_all(engine)#顶固删除数据库函数
def drop_db():Base.metadata.drop_all(engine)# drop_db()
# init_db()#创建mysql操作对象
Session = sessionmaker(bind=engine)
session = Session()

add:增加一个
add_all:增加多个

Session = sessionmaker(bind=engine)
session = Session()obj = Users(name='alex',extra='sb')
session.add(obj)
#add_all 列表形式
session.add_all([Users(name='cc',extra='cow'),Users(name='dd',extra='cowcow')
])
#提交
session.commit()

# 删
session.query(Users).filter(Users.id > 2).delete()# 提交
session.commit()

session.query(Users).filter(Users.id > 2).update({"name" : "099"})
session.query(Users).filter(Users.id > 2).update({Users.name: Users.name + "099"}, synchronize_session=False)
session.query(Users).filter(Users.id > 2).update({"num": Users.num + 1}, synchronize_session="evaluate")
session.commit()# 提交
session.commit()

ret=session.query(Users).all()
ret = session.query(Users.id, Users.extra).all()    #结果为一个列表
ret = session.query(Users).filter_by(name='cc').first()
ret = session.query(Users).filter_by(name='cc').all()print(type(ret))
print(ret[0].extra)

其他

条件:

# 条件
ret = session.query(Users).filter_by(name='alex').all()
ret = session.query(Users).filter(Users.id > 1, Users.name == 'eric').all()
ret = session.query(Users).filter(Users.id.between(1, 3), Users.name == 'eric').all()
ret = session.query(Users).filter(Users.id.in_([1,3,4])).all()
ret = session.query(Users).filter(~Users.id.in_([1,3,4])).all()
ret = session.query(Users).filter(Users.id.in_(session.query(Users.id).filter_by(name='eric'))).all()

与 或:

from sqlalchemy import and_, or_
ret = session.query(Users).filter(and_(Users.id > 3, Users.name == 'eric')).all()
ret = session.query(Users).filter(or_(Users.id < 2, Users.name == 'eric')).all()
ret = session.query(Users).filter(or_(Users.id < 2,and_(Users.name == 'eric', Users.id > 3),Users.extra != "")).all()

通配符 非:

ret = session.query(Users).filter(Users.name.like('e%')).all()
ret = session.query(Users).filter(~Users.name.like('e%')).all()

限制:

ret = session.query(Users)[1:2]

排序:

ret = session.query(Users).order_by(Users.name.desc()).all()
ret = session.query(Users).order_by(Users.name.desc(), Users.id.asc()).all()

分组:

from sqlalchemy.sql import funcret = session.query(Users).group_by(Users.extra).all()
ret = session.query(func.max(Users.id),func.sum(Users.id),func.min(Users.id)).group_by(Users.name).all()ret = session.query(func.max(Users.id),func.sum(Users.id),func.min(Users.id)).group_by(Users.name).having(func.min(Users.id) >2).all()

连表:

ret = session.query(Users, Favor).filter(Users.id == Favor.nid).all()ret = session.query(Person).join(Favor).all()ret = session.query(Person).join(Favor, isouter=True).all()

组合:

q1 = session.query(Users.name).filter(Users.id > 2)
q2 = session.query(Favor.caption).filter(Favor.nid < 2)
ret = q1.union(q2).all()q1 = session.query(Users.name).filter(Users.id > 2)
q2 = session.query(Favor.caption).filter(Favor.nid < 2)
ret = q1.union_all(q2).all()

Python操作MySQL之SQLAlchemy相关推荐

  1. python mysql数据库的高级应用_Python之路第十二天,高级(5)-Python操作Mysql,SqlAlchemy...

    Mysql基础 一.安装 Windows: 1.下载 http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.31-winx64.zip 2.解压 ...

  2. MySQL补充——索引,流程控制,数据备份,python操作mysql,SQLAlchemy

    一.索引 索引,是数据库中专门用于帮助用户快速查询数据的一种数据结构.类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,然后直接获取即可. 1.索引种类 普通索引:仅加速查询 唯一索 ...

  3. Python操作MySQL之SQLAlchemy的坑 老版本vs新版本

    老版本的useexisting已被废弃, 新版本使用extend_existing 老class CommentReply(db.Model):     __tablename__ = "w ...

  4. python操作三大主流数据库(6)python操作mysql⑥新闻管理后台功能的完善(增、ajax异步删除新闻、改、查)...

    python操作mysql⑥新闻管理后台功能的完善(增.删.改.查) 安装表单验证 D:\python\python_mysql_redis_mongodb\version02>pip inst ...

  5. Python 操作 MySQL 的5种方式(转)

    Python 操作 MySQL 的5种方式 不管你是做数据分析,还是网络爬虫,Web 开发.亦或是机器学习,你都离不开要和数据库打交道,而 MySQL 又是最流行的一种数据库,这篇文章介绍 Pytho ...

  6. Python操作MySQL分享

    Python操作MySQL Python操作MySQL 关于MySQL数据库 开始之前 _mysql模块 MySQLdb模块 1. 第一个例子 2. 创建并填充表 3. 取回数据 4. 字典游标 5. ...

  7. 15.python操作mysql

    15.python操作mysql 导入包 from pymysql import* 1. 创建 Connection 连接 conn=conne(host='192.168.13.130',port= ...

  8. python操作mysql操作步骤

    1.安装mysql pip install pymysql 2.导入pymysql from pymysql import * 3.创建数据库连接 conn = connect(host='local ...

  9. python2连接mysql_mysql-2:python操作mysql

    1.python操作mysql 安装MySQL-Python的包: pip install pymysql--import pymysql # pip install MySQLClient--imp ...

最新文章

  1. centos卸载harbor_【Harbor】Harbor镜像仓库的安装与历史版本镜像的清理
  2. Cisco ××× 完全配置指南-连载-PIX和ASA连接的故障诊断与排除
  3. 测试功能范围_IT8511+电子负载 OCP?测试功能
  4. creat_caltab生成六边形标定板(黑底白点)
  5. springmvc二十三:日期格式化
  6. 【MariaDB】MariaDB编译参数
  7. Spring Boot+Maven将配置文件打包到Jar包外方便运维修改配置
  8. Nginx/LVS/HAProxy负载均衡软件的优缺点详解
  9. Jenkins+Ant自动布署war
  10. GDAL更新至1.8.1后,通过属性查询矢量出错问题的解决方式
  11. BZOJ4401: 块的计数 思维题
  12. webots离线网页无法跳转
  13. 单网口RFC2544测试——信而泰网络测试仪实操
  14. 《java语言程序设计》泽勒一致性问题
  15. 导弹拦截(动态规划)
  16. HDU 6468 zyb的面试(找规律?)
  17. 浏览器默认首页被360导航篡改解决办法
  18. HBase源码阅读(一) balancer
  19. 硬核拆解自动驾驶工具链丨如何应对无人车部署落地的挑战?
  20. 8种网页数据的采集工具

热门文章

  1. openstack-Mitaka Glance上传镜像报错
  2. fork()会拷贝子线程吗?
  3. 弧形玻璃清洁机器人_宅家大扫除清洁装备+清洁好物+全屋家电维护一文搞定
  4. 服务器python密码_python实现批量修改服务器密码的方法
  5. spring_在Spring中使用多个动态缓存
  6. cad文本改宋体字型lisp_CAD绘图员必须掌握的15个高能技巧,别人3天工作量你半天搞定!...
  7. python合并多个excel为一个_Python合并多个Excel数据
  8. 基于Docker的开源端到端开发者平台
  9. 皮一皮:据说有个新娘打扮成了奥特曼...
  10. 皮一皮:钢铁直女?鉴定了,钢的不能再钢!