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模块的基本使用的更多相关文章

  1. python数据库操作之pymysql模块和sqlalchemy模块(项目必备)

    pymysql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同. 1.下载安装 pip3 install pymysql 2.操作数据库 (1).执行sql #! ...

  2. SQLAlchemy模块的使用教程

    数据库表是一个二维表,包含多行多列.把一个表的内容用Python的数据结构表示出来的话,可以用一个list表示多行,list的每一个元素是tuple,表示一行记录,比如,包含id和name的user表 ...

  3. python使用SQLAlchemy模块连接MySQL

    ORM技术:Object-Relational Mapping,负责把关系数据库的表结构映射到对象上. 1.安装SQLAlchemy,MySQLdb模块 MySQLdb安装教程:http://www. ...

  4. 第二百八十九节,MySQL数据库-ORM之sqlalchemy模块操作数据库

    MySQL数据库-ORM之sqlalchemy模块操作数据库 sqlalchemy第三方模块 sqlalchemysqlalchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API ...

  5. SQLalchemy模块用法

    安装 pip install sqlalchemy #!/usr/bin/env python # -*- coding:utf-8 -*- # 加载模块 from sqlalchemy.ext.de ...

  6. MySQL—ORM框架,sqlalchemy模块

    武老师博客:ORM框架介绍 import os #1.当一类函数公用同样参数时候,可以转变成类运行 - 分类 #2.面向对象: 数据和逻辑组合在一起了 #3. 一类事物共同用有的属性和行为(方法) # ...

  7. Python SQLAlchemy 模块

    SQLAlchemy 简介: SQLAlchemy 是用于实现 ORM(Object Relational Mapping,对象关系映射)的一个模块,即把数据库的表结构映射到对象上在 Python 中 ...

  8. Python与数据库[2] -> 关系对象映射/ORM[0] -> ORM 与 sqlalchemy 模块

    ORM 与 sqlalchemy 1 关于ORM / About ORM 1.1 ORM定义 / Definition of ORM ORM(Object Relational Mapping),即对 ...

  9. python学习之-- mysql模块和sqlalchemy模块

    简单介绍python下操作mysql数据库模块有2个:pyhton-mysqldb  和 pymysql 说明:在python3中支持mysql 的模块已经使用pymysql替代了MysqlDB(这个 ...

随机推荐

  1. OO第三次博客作业--第三单元总结

    一.JML 语言的理论基础及应用工具链 JML 是一种行为接口规格语言,提供了对方法和类型的规格定义手段.通过 JML 和其支持工具,不仅可以基于规格自动构造测试用例,并整合了 SMT Solver ...

  2. 热身训练2 Another Meaning

    题目来源 简要题意: 众所周知,在许多情况下,一个词语有两种意思.比如"hehe",不仅意味着"hehe",还意味着"excuse me". ...

  3. python2和python3并存下的pip使用

    py -2 -m pip install  *.whl py -3 -m pip intall *.wl

  4. 『学了就忘』Linux基础 — 4、VMware安装

    目录 1.VMware介绍 2.VMware主要特点 3.VMware建议配置 4.VMware安装 1.VMware介绍 VMware是一个虚拟PC的软件,可以在现有的操作系统上虚拟出一个新的硬件环 ...

  5. IRCUT作用

    IRCUT组成原理 IRCUT由两层滤光片组成,一片红外截止或吸收滤光片和一片全透光谱滤光片 白天是红外截止滤光片工作,晚上是全透滤光片工作,白天摄像头可以接收到人眼无法识别的红外线,会导致图像与肉眼 ...

  6. Gitlab-CI使用及.gitlab-ci.yml配置入门一篇就够了

    转载:Gitlab-CI使用及.gitlab-ci.yml配置入门一篇就够了 - 简书 (jianshu.com) 一. Gitlab-CI/CD使用场景 首先,公司使用Gitlab作为工作仓库进行代 ...

  7. jQuery根据地址获取经纬度

    一.HTML部分 1 @*景区位置*@ 2 <tr> 3 <th>景区名称:</th> 4 <td><input class="txt ...

  8. Luogu P1196 [NOI2002]银河英雄传说 | 并查集

    题目链接 并查集,具体看注释. #include<iostream> #include<cstdio> #include<cmath> using namespac ...

  9. cf 12C Fruits(贪心【简单数学】)

    题意: m个水果,n个价格.每种水果只有一个价格. 问如果给每种水果分配价格,使得买的m个水果总价格最小.最大. 输出最小值和最大值. 思路: 贪心. 代码: bool cmp(int a,int b ...

  10. cm1 逆向分析

    目录 cm1 逆向分析 前言 查壳分析 逆向分析 代码分析 qmemcpy分析 sub_401020函数分析 sub_401050函数分析 加密算法分析 POC代码编写 cm1 逆向分析 前言 还是先 ...