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. hdu 5185 Equation(分析+DP)

    题意: Gorwin is very interested in equations. Nowadays she gets an equation like thisx1+x2+x3+⋯+xn=n, ...

  2. C++类的静态成员变量与静态成员函数

    1.类的静态成员变量 C++类的静态成员变量主要有以下特性: 1.静态成员变量需要类内定义,类外初始化 2.静态成员变量不依赖于类,静态成员变量属于全局区,不属于类的空间. 3.静态成员变量通过类名访 ...

  3. vue mvc与mvvm

    一.什么是MVVM? MVVM是Model-View-ViewModel的缩写.MVVM是一种设计思想.Model 层代表数据模型,也可以在Model中定义数据修改和操作的业务逻辑:View 代表UI ...

  4. jquery 实现 <imput>标签 密码框显示/隐藏密码功能

    1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 < ...

  5. yum Multilib version problems

    这两天在更新CentOS7系统时,出现了Multilib version problems错误,执行命令: # yum update 出现了的错误信息: .... ---> Package li ...

  6. 五(一)、spring 声明式事务注解配置

    一.事务概述: 事务就是一系列的动作, 它们被当做一个单独的工作单元. 这些动作要么全部完成, 要么全部不起作用:比如 用户购买图书:购买动作之前需要确认 ①图书的数量是否足够:②用户账号余额是否足够 ...

  7. ELK集群之logstash(5)

    Logstash工作原理   Logstash事件处理有三个阶段:inputs → filters → outputs.是一个接收,处理,转发日志的工具.支持系统日志,webserver日志,错误日志 ...

  8. find 删除日志文件

    find 命令删除日志文件 find ./my_dir -mtime +10 -type f -delete EXPLANATIONS ./my_dir your directory (replace ...

  9. Java发展的重大事故

    1990年,在Sun计算机公司中,由Patrick Naughton.Mi keSheridan 及 James Gosling领导的小组Green Team,开发出的新的程序语言,命名为0ak, 后 ...

  10. webRTC中语音降噪模块ANS细节详解(四)

    上篇(webRTC中语音降噪模块ANS细节详解(三))讲了噪声的初始估计方法以及怎么算先验SNR和后验SNR. 本篇开始讲基于带噪语音和特征的语音和噪声的概率计算方法和噪声估计更新以及基于维纳滤波的降 ...