sqlalchemy模块的基本使用
Python中SQLAlchemy模块通过建立orm来对数据库进行操作
1. 建表
方式1
# -*- coding:utf-8 -*-
# Author:Wong Du from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String, DATE # 建立镜像连接
engine = create_engine("mysql+pymysql://caiyun:caiyun814@192.168.1.73/testdb") # 创建orm基类,用于建表结构继承使用
Base = declarative_base() # 创建表Student类
class Student(Base):
__tablename__ = 'student' # 表名
id = Column(Integer, nullable=False, primary_key=True, autoincrement=True)
name = Column(String(32), nullable=False)
register_date = Column(DATE) # 让查询到的数据变得可读
def __repr__(self):
return "id:%s name:%s date:%s"\
% (self.id, self.name, self.register_date) # 提交,创建表结构
Base.metadata.create_all(engine)
方式2
1 # -*- coding:utf-8 -*-
2 # Author:Wong Du
3
4 from sqlalchemy import Table, create_engine
5 from sqlalchemy import Column, Integer, String
6 from sqlalchemy.ext.declarative import declarative_base
7
8 # 建立镜像连接
9 engine = create_engine("mysql+pymysql://root:root814@111.230.64.164/testdb", echo=True)
10
11 # 创建orm基类,用于建表结构继承使用
12 Base = declarative_base()
13
14 # 建表
15 user = Table(
16 'user', Base.metadata, # ‘user’为表名,通过Base的metadata方法建表
17 Column('id', Integer, nullable=False, primary_key=True, autoincrement=True),
18 Column('name', String(32), nullable=False),
19 Column('password', String(64), nullable=False),
20 )
21
22 # 提交,创建表结构
23 Base.metadata.create_all(engine)
sqlalchemy_createTable2
方式3
1 # -*- coding:utf-8 -*-
2 # Author:Wong Du
3
4 from sqlalchemy import Table, MetaData, create_engine
5 from sqlalchemy import Column, Integer, String
6
7 # 创建镜像连接
8 engine = create_engine("mysql+pymysql://root:root814@111.230.64.164/testdb", echo=True)
9
10 # 创建orm对象
11 metadata = MetaData()
12
13 # 建表
14 user = Table(
15 'user2', metadata,
16 Column('id', Integer, nullable=False, primary_key=True, autoincrement=True),
17 Column('name', String(32), nullable=False),
18 Column('password', String(64), nullable=False),
19 )
20
21 metadata.create_all(engine)
sqlalchemy_createTable3
2. sqlalchemy筛选表内容基本操作
# -*- coding:utf-8 -*-
# Author:Wong Du import sqlalchemy_createTable
from sqlalchemy.orm import sessionmaker
from sqlalchemy import func # 通过绑定镜像连接生成会话类
Session_class = sessionmaker(bind=sqlalchemy_createTable.engine)
# 生成会话对象
session = Session_class() # 多条件查询,通过.query方法来查表,.filter方法来筛选表内容
sel_obj = session.query(sqlalchemy_createTable.Student)\
.filter(sqlalchemy_createTable.Student.id>0)\
.filter(sqlalchemy_createTable.Student.id<5).first() # 查询所有数据
sel_obj2 = session.query(sqlalchemy_createTable.Student).all()
sel_obj3 = session.query(sqlalchemy_createTable.Student).filter().all()
if sel_obj2 == sel_obj3:
print("效果相同") # like匹配&统计
sel_obj4 = session.query(sqlalchemy_createTable.Student)\
.filter(sqlalchemy_createTable.Student.name.like("%a%")).count()
print(sel_obj4) # 分组统计
sel_obj5 = session.query(
sqlalchemy_createTable.Student.name,
func.count(sqlalchemy_createTable.Student.name))\
.group_by(sqlalchemy_createTable.Student.name).all()
print(sel_obj5)
3. 其他操作
# -*- coding:utf-8 -*-
# Author:Wong Du import sqlalchemy_createTable
from sqlalchemy.orm import sessionmaker # 创建与engine镜像连接的数据库交互的类
Session_class = sessionmaker(bind=sqlalchemy_createTable.engine)
# 生成会话实例
session = Session_class() # 添加/插入表数据,创建要插入的数据对象
ins_stu_obj = sqlalchemy_createTable.Student(name='zhangsan', register_date='2019-12-12') # 将要操作的数据对象添加到会话实例中
session.add(ins_stu_obj) # 提交会话操作对象,使其真正生效
session.commit() # 关闭会话实例
session.close() # 查询表数据
'''
# filter_by关键字表达式,filter数据库SQL表达式,为空则匹配所有
# .first()获取匹配的第一条查询数据,.all()获取匹配的所有数据
# 格式1:session.query(表类名).filter_by(匹配关键字).first()
# 格式2:session.query(表类名).filter(匹配SQL语句).all()
# 获取查询到的表数据对象,为一个列表形式
sel_stu_obj = session.query(sqlalchemy_createTable.Student).filter_by(name='zhangsan').first()
sel_stu_obj2 = session.query(sqlalchemy_createTable.Student).filter(sqlalchemy_createTable.Student.id>0).all()
print(sel_stu_obj)
print(sel_stu_obj2)
print(sel_stu_obj2[1].name)
''' # 修改表数据
'''
# 获取要修改的表数据对象
upd_stu_obj = session.query(sqlalchemy_createTable.Student).filter_by(name='zhangsan').first()
print(upd_stu_obj)
upd_stu_obj.name = 'ZhangSan' session.commit()
sel = session.query(sqlalchemy_createTable.Student).filter_by().first()
print(sel) session.close()
''' # 回滚应用例子
upd = session.query(sqlalchemy_createTable.Student).filter(sqlalchemy_createTable.Student.id==7).all()
print(upd[0].register_date)
upd[0].register_date = '2008-10-01' ins = sqlalchemy_createTable.Student(name='WangWu', register_date='2018-12-12')
session.add(ins) print(session.query(sqlalchemy_createTable.Student).
filter(sqlalchemy_createTable.Student.register_date.
in_(['2008-10-01', '2018-12-12'])).all()) session.rollback() print(session.query(sqlalchemy_createTable.Student).
filter(sqlalchemy_createTable.Student.register_date.
in_(['2008-10-01', '2018-12-12'])).all())
4. 一对一外键
1 # -*- coding:utf-8 -*-
2 # Author:Wong Du
3
4 from sqlalchemy import create_engine
5 from sqlalchemy.ext.declarative import declarative_base
6 from sqlalchemy import Column, Integer, String, ForeignKey
7 from sqlalchemy.orm import sessionmaker, relationship
8
9 # 创建镜像连接
10 engine = create_engine("mysql+pymysql://caiyun:caiyun814@192.168.1.73/testdb?charset=utf8")
11 # 创建orm基类
12 Base = declarative_base()
13
14 class User(Base):
15 __tablename__ = 'user'
16 id = Column(Integer, nullable=False, primary_key=True, autoincrement=True)
17 name = Column(String(32), nullable=False)
18 passwd = Column(String(64), nullable=False, default='123456')
19
20 def __repr__(self):
21 return "<id:%d name:%s passwd:%s>" \
22 % (self.id, self.name, self.passwd)
23
24 class Addr(Base):
25 __tablename__ = 'addr'
26 id = Column(Integer, nullable=False, primary_key=True, autoincrement=True)
27 address = Column(String(32), default='X')
28 u_id = Column(Integer, ForeignKey('user.id'), nullable=False) # 配置外键
29
30 # 通过sqlalchemy内部方法把两张表外键关联起来,从而实现不同表数据的互相调用
31 user = relationship('User', backref='addr')
32
33 def __repr__(self):
34 return "<id:%d address:%s u_id:%d>" \
35 % (self.id, self.address, self.u_id)
36
37
38 Base.metadata.create_all(engine)
39
40
41 '''
42 --------------------------------------------------------------------------------------
43 华丽分隔线
44 --------------------------------------------------------------------------------------
45 '''
46
47 Session_class = sessionmaker(bind=engine)
48 session = Session_class()
49
50 # 插入
51 ins_user = User(name='dudu', passwd='dudu814')
52 # ins_user2 = User(name='hongfa', passwd='hongfa814')
53 # ins_user3 = User(name='jinglin', passwd='jinglin814')
54 #
55 # ins_addr = Addr(address='guangzhou', u_id=1)
56 # ins_addr2 = Addr(address='Guangdong', u_id=2)
57 # ins_addr3 = Addr(address='shenzhen', u_id=3)
58 # session.add_all( [ins_user, ins_user2, ins_user3,
59 # ins_addr, ins_addr2, ins_addr3] )
60 # session.commit()
61
62 sel_user = session.query(User).filter(User.name=='dudu').first()
63 print(sel_user)
64 print(sel_user.addr)
65 print(sel_user.addr[0].address)
66
67 print('\033[33;1m华丽分隔线\033[0m'.center(40, '-'))
68
69 sel_addr = session.query(Addr).all()
70 print(sel_addr)
71 print(sel_addr[2])
72 print(sel_addr[2].user)
73 print(sel_addr[2].user.passwd)
sqlalchemy_foreignkey
5. 一对多外键
1 # -*- coding:utf-8 -*-
2 # Author:Wong Du
3
4 from sqlalchemy import create_engine
5 from sqlalchemy.ext.declarative import declarative_base
6 from sqlalchemy import Column, Integer, String, ForeignKey
7 from sqlalchemy.orm import sessionmaker, relationship
8
9 engine = create_engine("mysql+pymysql://caiyun:caiyun814@localhost/testdb?charset=utf8")
10
11 Base = declarative_base()
12
13
14 class Taobao_addr(Base):
15 __tablename__ = 'taobao_addr'
16 id = Column(Integer, nullable=False, primary_key=True, autoincrement=True)
17 addr = Column(String(32), nullable=False, server_default='XXXXXXXXXXXXXXX')
18
19 def __repr__(self):
20 return "<id:%d addr:%s>" \
21 % (self.id, self.addr)
22
23 class Taobao_user(Base):
24 __tablename__ = 'taobao_user'
25 id = Column(Integer, nullable=False, primary_key=True, autoincrement=True)
26 name = Column(String(32), nullable=False, server_default='X')
27 home_addr_id = Column(Integer, ForeignKey('taobao_addr.id'), nullable=False)
28 work_addr_id = Column(Integer, ForeignKey('taobao_addr.id'), nullable=False)
29
30 # home_addr = relationship('Taobao_addr')
31 # work_addr = relationship('Taobao_addr')
32 home_addr = relationship('Taobao_addr', foreign_keys=home_addr_id)
33 work_addr = relationship('Taobao_addr', foreign_keys=work_addr_id)
34
35 def __repr__(self):
36 return "<id:%d name:%s home_addr_id:%d work_addr_id:%d>" \
37 %(self.id, self.name, self.home_addr_id, self.work_addr_id)
38
39 Base.metadata.create_all(engine)
40
41
42 '''
43 --------------------------------------------------------------------------------------
44 华丽分隔线
45 --------------------------------------------------------------------------------------
46 '''
47
48 Session_class = sessionmaker(bind=engine)
49 session = Session_class()
50
51 # 插入数据
52 '''
53 addr_list = ['ShenZhen', 'GuangZhou', 'BeiJing', 'ShangHai']
54 ins_addr_list = []
55 for i in addr_list:
56 obj = Taobao_addr(addr=i)
57 ins_addr_list.append(obj)
58 session.add_all(ins_addr_list)
59
60 ins_user = Taobao_user(name='dudu', home_addr_id=1, work_addr_id=4)
61 ins_user2 = Taobao_user(name='junry', home_addr_id=3, work_addr_id=3)
62 ins_user3 = Taobao_user(name='hongfa', home_addr_id=4, work_addr_id=2)
63 session.add_all([ins_user, ins_user2, ins_user3])
64
65 session.commit()
66 '''
67
68 # 查询数据
69 sel_user = session.query(Taobao_user).all()
70 print(sel_user)
71 print(sel_user[0].home_addr)
72 print(sel_user[0].id, sel_user[0].name,
73 sel_user[0].home_addr.addr,
74 sel_user[0].work_addr.addr)
sqlalchemy_manyforeignkey
sqlalchemy模块的基本使用的更多相关文章
- python数据库操作之pymysql模块和sqlalchemy模块(项目必备)
pymysql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同. 1.下载安装 pip3 install pymysql 2.操作数据库 (1).执行sql #! ...
- SQLAlchemy模块的使用教程
数据库表是一个二维表,包含多行多列.把一个表的内容用Python的数据结构表示出来的话,可以用一个list表示多行,list的每一个元素是tuple,表示一行记录,比如,包含id和name的user表 ...
- python使用SQLAlchemy模块连接MySQL
ORM技术:Object-Relational Mapping,负责把关系数据库的表结构映射到对象上. 1.安装SQLAlchemy,MySQLdb模块 MySQLdb安装教程:http://www. ...
- 第二百八十九节,MySQL数据库-ORM之sqlalchemy模块操作数据库
MySQL数据库-ORM之sqlalchemy模块操作数据库 sqlalchemy第三方模块 sqlalchemysqlalchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API ...
- SQLalchemy模块用法
安装 pip install sqlalchemy #!/usr/bin/env python # -*- coding:utf-8 -*- # 加载模块 from sqlalchemy.ext.de ...
- MySQL—ORM框架,sqlalchemy模块
武老师博客:ORM框架介绍 import os #1.当一类函数公用同样参数时候,可以转变成类运行 - 分类 #2.面向对象: 数据和逻辑组合在一起了 #3. 一类事物共同用有的属性和行为(方法) # ...
- Python SQLAlchemy 模块
SQLAlchemy 简介: SQLAlchemy 是用于实现 ORM(Object Relational Mapping,对象关系映射)的一个模块,即把数据库的表结构映射到对象上在 Python 中 ...
- Python与数据库[2] -> 关系对象映射/ORM[0] -> ORM 与 sqlalchemy 模块
ORM 与 sqlalchemy 1 关于ORM / About ORM 1.1 ORM定义 / Definition of ORM ORM(Object Relational Mapping),即对 ...
- python学习之-- mysql模块和sqlalchemy模块
简单介绍python下操作mysql数据库模块有2个:pyhton-mysqldb 和 pymysql 说明:在python3中支持mysql 的模块已经使用pymysql替代了MysqlDB(这个 ...
随机推荐
- 基于ImportBeanDefinitionRegistrar和FactoryBean动态注入Bean到Spring容器中
基于ImportBeanDefinitionRegistrar和FactoryBean动态注入Bean到Spring容器中 一.背景 二.实现方案 1.基于@ComponentScan注解实现 2.基 ...
- 算法:N-皇后问题
一.八皇后问题 八皇后问题是一个以国际象棋为背景的问题:如何能够在8 × 8 的国际象棋棋盘上放置八个皇后(Queen),使得任何一个皇后都无法直接吃掉其他的皇后.为了达到此目的,任两个皇后都不能处于 ...
- 15个问题自查你真的了解java编译优化吗?
摘要:为什么C++的编译速度会比java慢很多?二者运行程序的速度差异在哪? 了解了java的早期和晚期过程,就能理解这个问题了. 本文分享自华为云社区<你真的了解java编译优化吗?15个问题 ...
- python re:正向肯定预查(?=)和反向肯定预查(?<=)
参考资料:https://tool.oschina.net/uploads/apidocs/jquery/regexp.html (?=pattern) 正向肯定预查,在任何匹配pattern的字符串 ...
- JAVA笔记11__File类/File类作业/字节输出流、输入流/字符输出流、输入流/文件复制/转换流
/** * File类:文件的创建.删除.重命名.得到路径.创建时间等,是唯一与文件本身有关的操作类 */ public class Main { public static void main(St ...
- Envoy实现.NET架构的网关(五)集成Redis实现限流
什么是限流 限流即限制并发量,限制某一段时间只有指定数量的请求进入后台服务器,遇到流量高峰期或者流量突增时,把流量速率限制在系统所能接受的合理范围之内,不至于让系统被高流量击垮.而Envoy可以通过e ...
- Spring事务不生效问题
事务未生效可能造成严重的数据不一致性问题,因而保证事务生效至关重要.Spring事务是通过Spring aop实现的,所以不生效的本质问题是spring aop没生效,或者说没有代理成功,所以有必要了 ...
- vue路由监听和参数监听
1.路由携带数据跳转 routerAction(hideDisplays, data) { switch (hideDisplays) { case "pubAccountMenu" ...
- Centos 系统常用编译环境
centos编译环境配置 yum install -y autoconf make automake gcc gcc-c++
- request/response解决中文乱码!!!
Request中文乱码问题以及解决方案 补充三个知识点: Get是URL解码方式.默认解码格式是Tomcat编码格式.所以URL解码是UTF-8,覆盖掉了request容器解码格式 Post是实体内容 ...