flask 定义数据库关系(一对一)
一对一
我们将使用国家和首都来演示一对一关系:每个国家只有一个首都。反过来,一个城市也只能作为一个国家的首都。一对一关系如下:

在示例程序中,Country类表示国家,Capital类表示首都。建立一对一关系后,我们将在Country类中创建一个标量关系capital,调用它会获取单个Capital对象,我们还在Capital类中创建一个标量关系属性country,调用它会获取单个的Country对象。
一对一关系实际上是通过建立双向关系的一对多关系的基础上转化而来。我们要确保关系两侧的关系属性都是标量属性,都只返回单个值,所以要在定义集合属性的关系函数中将uselist参数设为False,这时一对多关系将被转换为一对一关系。下面代码基于建立双向关系的一对多关系实现了一对一关系。
app.py:建立一对一关系
class Country(db.Model):
id = db.Column(db.Integer, primary_key = True)
name = db.Column(db.String(30), unique = True)
capital = db.relationship('Capital', uselist = False) def __repr__(self):
return '<Country %r>' % self.name class Capital(db.Model):
id = db.Column(db.Integer, primary_key = True)
name = db.Column(db.String(30), unique = True)
country_id = db.Column(db.Integer, db.ForeignKey('country.id'))
country = db.relationship('Country') def __repr__(self):
return '<Capital %r>' % self.name
“多”这一侧本身就是标量关系属性,不用做任何改动(有外键的是“多”这一侧),而“一”这一侧的集合关系属性,通过将uselist设为False后,将仅返回对应的单个记录,而且无法再使用列表语义操作
>>> china = Country(name = 'China')
>>> beijing = Capital(name = 'Beijing')
>>> db.session.add(china)
>>> db.session.add(beijing)
>>> db.session.commit()
>>> china.capital
>>> china.capital = beijing
>>> china.capital
<Capital u'Beijing'>
>>> beijing.country
>>> beijing
<Capital u'Beijing'>
>>> db.session.commit()
>>> beijing
<Capital u'Beijing'>
>>> china.capital
<Capital u'Beijing'>
>>> china.capital.append('Tokyo')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
AttributeError: 'Capital' object has no attribute 'append'
flask 定义数据库关系(一对一)的更多相关文章
- flask 定义数据库关系(一对多)
		定义关系 在关系型数据库中,我们可以通过关系让不同表之间的字段建立联系.一般来说,定义关系需要两步,分别是创建外键和定义关系属性.在更复杂的多对多关系中,我们还需要定义关联表来管理关系.下面我们学习用 ... 
- flask 定义数据库关系(多对多)
		多对多 我们使用学生和老师来演示多对多关系:每个学生有多个老师,每个老师有多个学生.多对多关系示意图如下: 在实例程序中,Student类表示学生,Teacher类表示老师.在这两个模型之间建立多对多 ... 
- flask 定义数据关系(多对一)
		多对一 一对多关系反过来就是多对一关系,这两种关系模式分别从不同的视角出发.一个作者拥有多篇文章,反过来就是多篇文章属于同一个作者.为了便于区分,我们使用居民和城市来演示多对一关系:多个居民住在同一个 ... 
- 【Flask】ORM 关系一对一
		### 一对一的关系:在sqlalchemy中,如果想要将两个模型映射成一对一的关系,那么应该在父模型中,指定引用的时候,要传递一个`uselist=False`这个参数进去.就是告诉父模型,以后引用 ... 
- Flask之数据库设置
		4 数据库 知识点 Flask-SQLALchemy安装 连接数据库 使用数据库 数据库迁移 邮件扩展 4.1 数据库的设置 Web应用中普遍使用的是关系模型的数据库,关系型数据库把所有的数据都存储在 ... 
- Python进阶----表与表之间的关系(一对一,一对多,多对多),增删改查操作
		Python进阶----表与表之间的关系(一对一,一对多,多对多),增删改查操作,单表查询,多表查询 一丶表与表之间的关系 背景:      由于如果只使用一张表存储所有的数据,就会操作数 ... 
- 开始VS 2012 中LightSwitch系列的第2部分:感受关爱——定义数据关系
		[原文发表地址] Beginning LightSwitch in VS 2012 Part 2: Feel the Love - Defining Data Relationships [原文发表 ... 
- C++中重定义的问题——问题的实质是声明和定义的关系以及分离式编译的原理
		这里的问题实质是我们在头文件中直接定义全局变量或者函数,却分别在主函数和对应的cpp文件中包含了两次,于是在编译的时候这个变量或者函数被定义了两次,问题就出现了,因此,我们应该形成一种编码风格,即: ... 
- BI之SSAS完整实战教程6 -- 设计维度、细化维度上:创建维度定义特性关系
		前面我们使用过数据源向导.数据源视图向导.Cube向导来创建相应的对象. 本篇我们将学习使用维度向导来创建维度. 通过前面几个向导的学习,我们归纳一下共同点,主要分成两步 1. 使用某种对象类型的向导 ... 
随机推荐
- [hive] hive 内部表和外部表
			1.内部表 hive (test1)> create table com_inner_person(id int,name string,age int,ctime timestamp) row ... 
- Window 产品密钥
			2019.4.2 测试可用 window2003 DF74D-TWR86-D3F4V-M8D8J-WTT7M 
- http://www.rehack.cn/techshare/webbe/php/3391.html
			首先配置好本地PHPstudy环境: 默认在D:\phpStudy\php\php-7.0.12-nts\ext目录下有php_pdo_sqlsrv_7_nts_x86.dll.php_sqlsrv_ ... 
- JVM监控和调优常用命令工具总结
			JVM监控和调优 在Java应用和服务出现莫名的卡顿.CPU飙升等问题时总是要分析一下对应进程的JVM状态以定位问题和解决问题并作出相应的优化,在这过程中Java自带的一些状态监控命令和图形化工具就非 ... 
- express中间件--Morgan 日志记录
			Morgan是一个node.js关于http请求的日志中间件 安装模块 npm install morgan --save #保存到package.json的依赖列表1使用方法 在终端打印日志...v ... 
- ES6 export
			一.默认导出(default export)// 1.一个模块只能有一个默认导出, 对于默认导出, 导入的名称可以和导出的名称不一致, 这对于导出匿名函数或类非常有用. <!---- page. ... 
- 记一次Springboot启动异常
			启动Springboot项目报以下异常: org.springframework.context.ApplicationContextException: Unable to start web se ... 
- TS的一些小东西
			首先介绍下泛型的三种方法,函数声明,函数表达式,箭头函数 function Interview2<T>(name:T):T{ return name } let mn=function&l ... 
- 【转载】python抓取网页时候,判断网页编码格式
			在web开发的时候我们经常会遇到网页抓取和分析,各种语言都可以完成这个功能.我喜欢用python实现,因为python提供了很多成熟的模块,可以很方便的实现网页抓取.但是在抓取过程中会遇到编码的问题, ... 
- 逆向工程之修改关键CALL返回值_破解视频转换专家
			1)注册软件随便输入注册名注册码 2)进入软件根目录,发送到PEID查壳 3)发现无壳 4)发送到OD 4.1)右键菜单选择智能搜索 4.2)找到关键信息点注册 4.3)找到关键信息点双击进入汇编,向 ... 
