SqlAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简而言之:将对象转换成SQL,然后使用数据API执行SQL并获取执行结果。
ORM(对象关系映射)方法论基于三个核心原则:
- 简单:以最基本的形式建模数据
- 传达性:数据库结构被任何人都能理解的语言文档化
- 精准性:基于数据模型创建正确标准化了的结构
Dialect用于和数据API进行交流,根据配置文件的不同调用的数据库API,从而实现对数据库的操作,如:
‘数据库类型+数据库驱动名称://用户名:口令@机器地址:端口号/数据库名‘
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
|
基本操作
(1)连接数据库:create_engine()
engine = create_engine("mysql+pymysql://root:12[email protected]:3306/wang", max_overflow=5)
- create_engine() 会返回一个数据库引擎
- mysql+pymysql “指定一个使用pymysql来连接”
- 使用用户名‘root‘和密码‘123456‘来连接数据库‘wang‘
- max_overflow 是最大连接数
- charset : 设定连接时使用的字符集 charset = utf8
- echo 参数如果为True时,会显示每条执行的SQL语句,生产环境下课关闭
(2)字段和数据类型及操作方法
在sqlalchemy.scherma包里有数据库关系的描述,列举几个常用的:
- 字段 : Column
- 索引 :Index
- 表:Table
数据类型在sqlalchemy.types包,列举常用的:
- 二进制:BIGINT
- 布尔:BOOLEAN
- 字符:CHAR
- 可变字符:VARCHAR
- 日期:DATATIME
(3)创建表结构
使用Schema Type/SQL Expression Language/Engine/ConnectionPooling/Dialect进行数据库操作。Engine使用Schema Type创建一个特定的结构对象,之后通过SQL Expression Language将该对象转换成SQL语句,然后通过ConnectionPooling连接数据库,再然后通过Dialect执行SQL,并获取结果。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
继承式增删改查
使用ORM/Schema Type/SQL Expression Language/Engine/ConnectionPooling/Dialect所有组件对数据库进行操作。根据类创建对象,对象转换成SQL,再执行SQL。
Query对象可以返回迭代的值(iterator value),然后我们可以通过for in 来查询。不过Query对象的all(), one()以及first()方法将返回非迭代值(non-iterator value),比如说all() 返回的是一个列表, first()方法限制并且仅作为标量返回结果集的第一条记录。
(1)创建数据库
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
(2)增加
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
|
(3)删除
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
|
(4)修改
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
(5)查询
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
|
(6)外键关联
由于关系型数据的多个表还可以用外键实现一对多,多对多等关联,相应的,ORM框架也可以提供两个对象之间的一对多,多对多等功能,
- 一对多(一个User可以有多个Address)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 |
|
- 多对多
建立一个双向一对多关系,“反向”是一个许多人,指定一个额外的relationship()函数,并连接两个使用relationship.back_populates参数。简单来说,relationship函数是sqlalchemy对关系之间提供的一种便利的调用方式,backref参数则对关系提供反向引用的声明。在最新版的sqlalchemy中对relationship引进了back_populates参数。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 |
|
- 多对多之三表外键关联
-
12
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#!/usr/bin/env python3
#coding:utf8
from
sqlalchemy
import
create_engine,func,Table
from
sqlalchemy.ext.declarative
import
declarative_base
from
sqlalchemy
import
Column, Integer, String,ForeignKey
from
sqlalchemy.orm
import
sessionmaker,relationship
Base
=
declarative_base()
# 关系表
Host2Group
=
Table(
‘host_2_group‘
,Base.metadata,
Column(
‘host_id‘
,ForeignKey(
‘hosts.id‘
),primary_key
=
True
),
Column(
‘group_id‘
,ForeignKey(
‘group.id‘
),primary_key
=
True
),
)
engine
=
create_engine(
"mysql+pymysql://root:[email protected]:3306/wang"
, max_overflow
=
5
)
class
Host(Base):
__tablename__
=
‘hosts‘
id
=
Column(Integer,primary_key
=
True
,autoincrement
=
True
)
hostname
=
Column(String(
64
),unique
=
True
,nullable
=
False
)
ip_addr
=
Column(String(
128
),unique
=
True
,nullable
=
False
)
port
=
Column(Integer,default
=
22
)
groups
=
relationship(
‘Group‘
,
secondary
=
Host2Group,
backref
=
‘host_list‘
)
class
Group(Base):
__tablename__
=
‘group‘
id
=
Column(Integer,primary_key
=
True
)
name
=
Column(String(
64
),unique
=
True
,nullable
=
False
)
Base.metadata.create_all(engine)
# 创建所有表结构
if
__name__
=
=
‘__main__‘
:
SessionCls
=
sessionmaker(bind
=
engine)
session
=
SessionCls()
g1
=
Group(name
=
‘g1‘
)
g2
=
Group(name
=
‘g2‘
)
g3
=
Group(name
=
‘g3‘
)
g4
=
Group(name
=
‘g4‘
)
session.add_all([g1,g2,g3,g4])
session.commit()
原文地址:https://www.cnblogs.com/meng-wei-zhi/p/8259019.html