django model Foreign key usage 关系型数据库 ORM
django
的模型
from django.db import models
"""
A model pair to map car and its manufacturer
""" class Manufacturer(models.Model):
brand = models.CharField(max_length=100)
location = models.CharField(max_length=100) def __unicode__(self):
return self.brand class Meta:
ordering = ["brand"] class Car(models.Model):
owner = models.CharField(max_length=100)
volume = models.CharField(max_length=100)
manufacturer = models.ForeignKey('Manufacturer')
is_active = models.BooleanField(default=True) def __unicode__(self):
return self.owner class Meta:
ordering = ["owner"]
每个车只有一个车主,每个车来自与只有一个工厂。可是这个工厂确有很多车。
先用的django 生成数据表 python manage.py syncdb (P.S. python manage.py validate 是用来查看数据库模型是否有问题的选项的 ,挺有用的)
这样看一下就明白了

其实可以先固定几款车型,这样,很多人都可以同时指向一款车了,比如说,大家都买了了上面对象 m2 的车,或者m3的车。
django帮你自动搞定,这些数据库操作。ForeignKey非常爽的用的说。
简单来说,django 里面 属性如果设置成了 manufacturer = models.ForeignKey('Manufacturer') 了的话,
新建该有ForeignKey属性的 对象的时候, 这个属性要是一个 该ForeignKey的 class 对象实例。 很科学!
其实感觉就如同这样:
>>> m3 = Manufacturer(brand="BMW", location="Germany")
>>> m3.save()
>>> lily = Car(owner = "Lily", volume = "1.4T", manufacturer = m3)
>>> lily.save()
>>> lily.manufacturer
<Manufacturer: BMW>
>>> lily.manufacturer = m2
>>> lily.save()
>>> lily.manufacturer
<Manufacturer: Toyota>
>>> lily.manufacturer.location
'Japan'
神奇之处
django model Foreign key usage 关系型数据库 ORM的更多相关文章
- Node的关系型数据库ORM库:bookshelf
		NodeJs 关系数据库ORM库:Bookshelf.js bookshelf.js是基于knex的一个关系型数据库的ORM库.简单易用,内置了Promise的支持.这里主要罗列一些使用的例子,例子就 ... 
- django model改变后,同步数据库
		在使用django进行开发时,往往需要根据不同的需求对model进行更改.而这时候,python manage.py syncdb就不好使了. 目前有个很好的工具,是south,这个是专门用来更改mo ... 
- SQLServer之FOREIGN KEY约束
		FOREIGN KEY约束添加规则 1.外键约束并不仅仅可以与另一表的主键约束相链接,它还可以定义为引用另一个表中 UNIQUE 约束的列. 2.如果在 FOREIGN KEY 约束的列中输入非 NU ... 
- 关系型数据库中主键(primary key)和外键(foreign key)的概念。
		刚接触关系型数据库的同学,会听过主键和外键的概念.这是关系型数据库的基本概念,需要清楚理解.今天我就以简洁的语言总结一下这个概念. 主键.一句话概括:一张表中,可以用于唯一标识一条记录的字段组(或者说 ... 
- Django之 数据库ORM
		一.ORM Django的 业务 少不了 跟数据库打交道,不然没有数据库保存一些数据将是一件很糟糕的事情.Django 对 数据库 支持原生的 SQL语句,但更好的对数据库支持,Django自己有一套 ... 
- django之数据库orm
		一.数据库的配置 1 django默认支持sqlite,mysql, oracle,postgresql数据库. <1>sqlite django默认使用sqlite的数据库,默认自带sq ... 
- 03: Django Model数据库操作
		目录:Django其他篇 01:Django基础篇 02:Django进阶篇 03:Django数据库操作--->Model 04: Form 验证用户数据 & 生成html 05:Mo ... 
- 02:django model数据库操作
		Django其他篇 目录: 1.1 Django中使用MySQL 1.2 创建表 1.3 Django一对多表结构操作 1.4 Django多对多表结构操作 1.5 一大波Model操作 1.6 Mo ... 
- Django中的app及mysql数据库篇(ORM操作)
		Django常见命令 在Django的使用过程中需要使用命令让Django进行一些操作,例如创建Django项目.启动Django程序.创建新的APP.数据库迁移等. 创建Django项目 一把我们都 ... 
随机推荐
- github basic usage in windows
			1. create a new accout, create orginazation, create repo 2. install git in your local pc Note: you c ... 
- js模块开发
			js模块开发(一) 现在嵌入页面里面的javascript代码越来越复杂,于是可能依赖也越来越严重,使用别人开发的js也越来越多,于是在理想情况下,我们只需要实现核心的业务逻辑,其他都可以加载别人已经 ... 
- 编译预处理  --  带参数的宏定义--【sky原创】
			原文:编译预处理 -- 带参数的宏定义--[sky原创] 如有转载请注明出处 编译预处理 -- 带参数的宏定义 前面为输出文件,后面为输入文件 gcc -E -o test.i test.c ... 
- 讲故事的人写的谈判手册——Leo锦书64
			正如其名称所暗示这本书"谈判无处不在".从决定谈判的成功或失败的因素一个不同的观点,测量中详细给出的同一时间. 图书出版不错,这是阅读的样车.阅读收获压力较小的方式. 书能给读 ... 
- Math.random引发的骗术,绝对是用随机数骗前端妹纸的最佳方法
			我觉得今天我运气特好,今天我们来赌一赌,我们来搞个随机数,Math.floor(Math.random() * 10),如果这个数等于0到7,这个月的饭,我全请了,如果是8或9,你就请一个礼拜成不?于 ... 
- TestNg的xml配置
			TestNG中,可以通过配置xml来运行某一类.包.方法. 1.通过TestNg运行某一个类 <?xml version="1.0" encoding="UTF-8 ... 
- Mvc 下载文件
			你如何将文件传送给用户取决于你最开始如何存储它,如果你将文件存入数据库,你会用流的方式将文件返还给用户,如果你将文件存在硬盘中,你只需要提供一个超链接即可,或者也可以以流的方式.每当你需要以流的方式将 ... 
- openwrt路由器更换了Flash之后需要修改的源码
			假如我使用的是WR703N,改为8M内存: 1 修改openwrt/target/linux/ar71xx/image/Makefile文件 $(eval $(call SingleProfile,T ... 
- mediawiki在windows下的安装
			mediawiki在windows下的安装 对于刚接触wiki的朋友们来说,配置一个服务器环境,安装并运行mediawiki是一件很麻烦的事情,在这里,我尽量用通俗易懂的语言,介绍mw(mediawi ... 
- 【转】android 欢迎界面翻页成效,仿微信第一次登陆介绍翻页界面
			android 欢迎界面翻页效果,仿微信第一次登陆介绍翻页界面 本实例做的相对比较简单主要是对翻页控件的使用,有时候想要做一些功能是主要是先了解下是否有现成的控件可以使用,做起来比较简单不用费太大的劲 ... 
