flask中MySQL外键_flask 外键关系和多对多查询

好久没有更新Blog了

今天来聊一聊 Python 的 ORM 框架 SQLAlchemy 有些同学已经听说过这个框架的大名了,也听说了 SQLAlchemy 没有 Django 的 Models 好用

我在这里官宣辟谣一下啊, Models 紧紧只是配置和使用比较简单(这特么就是废话),因为他是Django自带的ORM框架,也正是因为是Django原生的,所以兼容性远远不如SQLAlchemy

真正算得上全面的ORM框架必然是我们的SQLAlchemy ORM框架,它可以在任何使用SQL查询时使用

当然了,无论是使用什么ORM框架,都是为了方便不熟练数据库的同学使用的,我个人还是比较推崇原生 SQL ,也建议每位同学攻克 SQL 的难关

废话不多说,我们来看一下 SQLAlchemy 如何使用:

1.创建数据表

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

1 #ORM中的数据表是什么呢?

2 #Object Relation Mapping

3 #Object - Table 通过 Object 去操纵数据表

4 #从而引出了我们的第一步创建数据表 - 创建Object

5 #1. 创建Object

6 #class User(object):

7 #pass

8

9 #2. 让Object与数据表产生某种关系 也就是让Object与数据表格式极度相似

10 #导入官宣基础模型

11 from sqlalchemy.ext.declarative importdeclarative_base12 #实例化官宣模型 - Base 就是 ORM 模型

13 Base =declarative_base()14 #当前的这个Object继承了Base也就是代表了Object继承了ORM的模型

15 class User(Base): #相当于 Django Models中的 Model

16 #为Table创建名称

17 __tablename__ = "user"

18 #创建ID数据字段 , 那么ID是不是一个数据列呢? 也就是说创建ID字段 == 创建ID数据列

19 from sqlalchemy importColumn,Integer,String20 #id = Column(数据类型,索引,主键,外键,等等)

21 #int == Integer

22 id = Column(Integer,primary_key=True,autoincrement=True)23 #str == char(长度) == String(长度)

24 name = Column(String(32),index=True)25

26 #3.去数据库中创建数据表? or 先连接数据库?

27 #3.去连接数据库 创建数据引擎

28 from sqlalchemy importcreate_engine29 #创建的数据库引擎

30 engine = create_engine("mysql+pymysql://root:DragonFire@127.0.0.1:3306/dragon?charset=utf8")31

32 #Base 自动检索所有继承Base的ORM 对象 并且创建所有的数据表

33 Base.metadata.create_all(engine)

48304ba5e6f9fe08f3fa1abda7d326ab.png

my_create_table

2.增删改查操作

2.1.增加数据

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

1 #insert 为数据表增加数据

2 #insert One 增加一行数据

3 #insert into user(name) values ("DragonFire")

4 #在ORM中的操作:

5 #1.首先导入之间做好的ORM 对象 User

6 from my_create_table importUser7 #2.使用Users ORM模型创建一条数据

8 user1 = User(name="DragonFire")9 #数据已经创建完了,但是需要写入到数据库中啊,怎么写入呢?

10 #3.写入数据库:

11 #首先打开数据库会话 , 说白了就是创建了一个操纵数据库的窗口

12 #导入 sqlalchemy.orm 中的 sessionmaker

13 from sqlalchemy.orm importsessionmaker14 #导入之前创建好的 create_engine

15 from my_create_table importengine16 #创建 sessionmaker 会话对象,将数据库引擎 engine 交给 sessionmaker

17 Session =sessionmaker(engine)18 #打开会话对象 Session

19 db_session =Session()20 #在db_session会话中添加一条 UserORM模型创建的数据

21 db_session.add(user1)22 #使用 db_session 会话提交 , 这里的提交是指将db_session中的所有指令一次性提交

23 db_session.commit()24

25 #当然也你也可很任性的提交多条数据

26 #方法一:

27 user2 = User(name="Dragon")28 user3 = User(name="Fire")29 db_session.add(user2)30 db_session.add(user3)31 db_session.commit()32 #之前说过commit是将db_session中的所有指令一次性提交,现在的db_session中至少有两条指令user2和user3

33 db_session.close()34 #关闭会话

35

36 #如果说你觉得方法一很麻烦,那么方法二一定非常非常适合你

37 #方法二:

38 user_list =[39 User(name="Dragon1"),40 User(name="Dragon2"),41 User(name="Dragon3")42 ]43 db_session.add_all(user_list)44 db_session.commit()45

46 db_session.close()

48304ba5e6f9fe08f3fa1abda7d326ab.png

orm_insert

2.2.查询数据

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1 #ORM操作查询数据

2 #有了刚才Insert增加数据的经验,那么查询之前的准备工作,就不用再重复了吧

3 #回想一下刚才Insert时我们的操作

4 from my_create_table importUser, engine5 from sqlalchemy.orm importsessionmaker6

7 Session =sessionmaker(engine)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值