Python操作MySQL之SQLAlchemy
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相关推荐
- 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.解压 ...
- MySQL补充——索引,流程控制,数据备份,python操作mysql,SQLAlchemy
一.索引 索引,是数据库中专门用于帮助用户快速查询数据的一种数据结构.类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置,然后直接获取即可. 1.索引种类 普通索引:仅加速查询 唯一索 ...
- Python操作MySQL之SQLAlchemy的坑 老版本vs新版本
老版本的useexisting已被废弃, 新版本使用extend_existing 老class CommentReply(db.Model): __tablename__ = "w ...
- python操作三大主流数据库(6)python操作mysql⑥新闻管理后台功能的完善(增、ajax异步删除新闻、改、查)...
python操作mysql⑥新闻管理后台功能的完善(增.删.改.查) 安装表单验证 D:\python\python_mysql_redis_mongodb\version02>pip inst ...
- Python 操作 MySQL 的5种方式(转)
Python 操作 MySQL 的5种方式 不管你是做数据分析,还是网络爬虫,Web 开发.亦或是机器学习,你都离不开要和数据库打交道,而 MySQL 又是最流行的一种数据库,这篇文章介绍 Pytho ...
- Python操作MySQL分享
Python操作MySQL Python操作MySQL 关于MySQL数据库 开始之前 _mysql模块 MySQLdb模块 1. 第一个例子 2. 创建并填充表 3. 取回数据 4. 字典游标 5. ...
- 15.python操作mysql
15.python操作mysql 导入包 from pymysql import* 1. 创建 Connection 连接 conn=conne(host='192.168.13.130',port= ...
- python操作mysql操作步骤
1.安装mysql pip install pymysql 2.导入pymysql from pymysql import * 3.创建数据库连接 conn = connect(host='local ...
- python2连接mysql_mysql-2:python操作mysql
1.python操作mysql 安装MySQL-Python的包: pip install pymysql--import pymysql # pip install MySQLClient--imp ...
最新文章
- centos卸载harbor_【Harbor】Harbor镜像仓库的安装与历史版本镜像的清理
- Cisco ××× 完全配置指南-连载-PIX和ASA连接的故障诊断与排除
- 测试功能范围_IT8511+电子负载 OCP?测试功能
- creat_caltab生成六边形标定板(黑底白点)
- springmvc二十三:日期格式化
- 【MariaDB】MariaDB编译参数
- Spring Boot+Maven将配置文件打包到Jar包外方便运维修改配置
- Nginx/LVS/HAProxy负载均衡软件的优缺点详解
- Jenkins+Ant自动布署war
- GDAL更新至1.8.1后,通过属性查询矢量出错问题的解决方式
- BZOJ4401: 块的计数 思维题
- webots离线网页无法跳转
- 单网口RFC2544测试——信而泰网络测试仪实操
- 《java语言程序设计》泽勒一致性问题
- 导弹拦截(动态规划)
- HDU 6468 zyb的面试(找规律?)
- 浏览器默认首页被360导航篡改解决办法
- HBase源码阅读(一) balancer
- 硬核拆解自动驾驶工具链丨如何应对无人车部署落地的挑战?
- 8种网页数据的采集工具
热门文章
- openstack-Mitaka Glance上传镜像报错
- fork()会拷贝子线程吗?
- 弧形玻璃清洁机器人_宅家大扫除清洁装备+清洁好物+全屋家电维护一文搞定
- 服务器python密码_python实现批量修改服务器密码的方法
- spring_在Spring中使用多个动态缓存
- cad文本改宋体字型lisp_CAD绘图员必须掌握的15个高能技巧,别人3天工作量你半天搞定!...
- python合并多个excel为一个_Python合并多个Excel数据
- 基于Docker的开源端到端开发者平台
- 皮一皮:据说有个新娘打扮成了奥特曼...
- 皮一皮:钢铁直女?鉴定了,钢的不能再钢!