django 外键操作】的更多相关文章

下面定义两个模型,一个主表,一个字表. 举例说明: 如何通过主表对象找到对应的子表对象? 如何通过子表对象找到对应的主表对象? class Person(models.Model); name = models.CharField('作者姓名', max_length=10) age = models.IntegerField('作者年龄') class Book(models.Model): person = models.ForeignKey(Person,related_name='per…
一.内容回顾 1.Django请求的生命周期: ​ 路由系统 -> 视图函数(获取模板+数据 -> 渲染) -> 字符串返回给用户 2.路由系统: /index/ #-> 函数或类.as_view() /detail/(\d+) #-> 函数(参数) 或 类.as_view()(参数) /detail/(?P<nid>\d+) #-> 函数(参数) 或 类.as_view()(参数) /detail/ #-> include("app01.u…
Django---Django的ORM的一对多操作(外键操作),ORM的多对多操作(关系管理对象),ORM的分组聚合,ORM的F字段查询和Q字段条件查询,Django的事务操作,额外(Django的终端打印SQL语句,脚本调试) 一丶Django的ORM外键操作 通过对象查找 ### 正向查找 # 获得图书对象 book_obj=models.Book.objects.get(pk=1) ret=book_obj.pub #pub是Book表的外键字段,存在Book表中. 通过pub可以拿到所关…
1.orm外键操作 创建外键: 备注:ForeignKey两个参数,1个为关联的表名,1个为关联的字段名: 在django2.0后,定义外键和一对一关系的时候需要加on_delete选项,此参数为了避免两个表里的数据不一致问题 当建完表后,我们发现在sqlite中,cmdb_userinfo表中字段,usergroup字段名称发生了变更,变更为usergroup_id. 当我们使用obj=models.UserInfo.objects.all()时,可以通过obj.的方式,找到usergroup…
Django ORM 外键操作 经常修改的东西一般不放到内存里面,而是放到一张表里.表跟表之间是可以存在关系的,最基本的就是一对多的关系. models.ForeignKey(ColorDic) 1. 在models.py中创建2张表,UserGroup中有2列数据,UserInfo中有3列数据. from django.db import models # Create your models here. class UserGroup(models.Model): uid=models.Au…
Django支持修改表结构 把max_length=64 改为60 再执行一遍 python manage.py makemigrations python manage.py migrate 如果是增加一列 再执行一遍 python manage.py makemigrations 会出现众多选项 如果选择1,会让你输入一个默认值  我们输入“alex” 再执行python manage.py migrate 就更新了数据库 ------------- 如果新加的一列可为空值Null 再执行一…
外键约束示例 #models操作如下 class HostInfo(models.Model): servername = models.CharField(max_length=) serverip = models.CharField(max_length=) serverpassword = models.CharField(max_length=) server_group = models.ForeignKey("GroupInfo",to_field="id&qu…
以MYSQL为例: (1)在model中定义两个数据表,食物信息和食物类别信息 class foodInfo(models.Model):     food_id = models.AutoField(max_length=4)   #自定义主键,不指定主键默认会生成一个名为‘ID’列的主键     food_name = models.CharField(max_length=10)     food_content = models.CharField(max_length=100)    …
第1章 Django ORM相关操作 1.1 在一个py文件中使用django项目 1.2 返回QuerySet对象的方法有 1.2.1 特殊的QuerySet 1.3 返回具体对象的 1.4 返回布尔值的方法有:1.5 返回数字的方法有 1.6 表单查询-双下划线 1.6.1 id__lt 1.6.2 id__in 1.6.3 name__contains 1.6.4 icontains 1.6.5 id__range 1.6.6 其它 第2章 ForeignKey操作(重点) 2.1 例:…
当你在Django中删除了一个有着外键关联的数据时,比如一个作者和他名下的所有的书的信息,书的外键是作者(一个作者可有好多本书),当你把作者的信息从数据库中删除时,Django提供了一下几个参数来对作者的书的数据进行操作 外键的定义: #models.pyclass Author(models.Model):    author = models.CharField(max_length=250) class Books(models.Model):     book = models.Fore…
data sqlite> select * from author; id name age 1 jim 12 2 tom 11 sqlite> select * from book; id name author_id 1 learn java 1 2 learn python 1 3 learn c++ 2 models.py # -*- coding: UTF-8 -*- from __future__ import unicode_literals from django.db imp…
Django的外键使用 from django.db import models # Create your models here. class Category(models.Model): name = models.CharField(max_length=) class Article(models.Model): title = models.CharField(max_length=) content = models.TextField() # 是由Category影响Artic…
models.py from django.db import models # Create your models here. class Category(models.Model): """ 文章分类 """ name = models.CharField(verbose_name='分类',max_length=32) class Article(models.Model): """ 文章表 "&…
1. 一对多 model.py class UserTest(models.Model): name = models.CharField(max_length = 16 ) sex = models.CharField(max_length = 16 ) hobby = models.CharField(max_length = 32 ) class Ariticle(models.Model): title = models.CharField(max_length = 32 ) conte…
models.py class UserInfo(models.Model): username = models.CharField(max_length=64,db_column='username') passwd = models.CharField(max_length=64,db_column='password') register_date = models.DateTimeField(max_length=32,db_column='register_date') last_l…
1.HTML代码: <td> <select id="depend_case" name="depend_case"> <option value="" {% if clickandback.depend_case_id == None %} selected="selected" {% endif %}> ---请选择 </option> {%for cab in clicka…
外键: ·一对多 ·多对多 ·一对一 ·修改表 ·复制表   主键:   rimary key auto_increment(primary key是主键通常和auto_increment自动增加混合使用) 把所有数据存放到一张表中的弊端: 组织结构不清晰 浪费硬盘空间 扩展性差 一对多 create table school( id int primary key auto_increment,    #primary key设置主键 school_name char(60) );create…
AutoField(Field) - int自增列,必须填入参数 primary_key=True BigAutoField(AutoField) - bigint自增列,必须填入参数 primary_key=True 注:当model中如果没有自增列,则自动会创建一个列名为id的列 from django.db import models class UserInfo(models.Model): # 自动创建一个列名为id的且为自增的整数列 username = models.CharFie…
models.py: from django.db import models # 出版社 class Publisher(models.Model): id = models.AutoField(primary_key=True) name = models.CharField(max_length=64, null=False, unique=True) def __str__(self): return "<Publisher object: {}>".format(…
https://blog.csdn.net/hpu_yly_bj/article/details/78939748 related_name表面作用 加上 核心related_name作用 https://blog.csdn.net/lanyang123456/article/details/68962515 定义表Apple: class Apple( models.Model): origin_level = models.ForeignKey(AppleLevel) new_level =…
表结构 CREATE TABLE [staff] ( [id] [varchar](50) NOT NUL L, [name] [varchar](50) NOT NULL, [password] [varchar](50) NULL, [roleid] [varchar](50) NULL, [account] [varchar](50) NULL, [tel] [varchar](50) NULL, ) 增加列 : alter table staff add sex varchar(50)…
Django 外键创建 关键语法: models.ForeignKey("UserGroup",to_field="gid",default=1,on_delete=models.CASCADE) 参数: "UserGroup"  #外键另外一张表 to_field="gid" #另外一张表的字段 on_delete=models.CASCADE  #因为不加这个会报错相关(https://www.cnblogs.com/ph…
Django 模型建立外键 在模型中建立外键是很简单的,基本操作如下 class Table(models.Model) column_name = models.ForeignKey(other-TableClassName) 来看看这个模型(models.py)是啥: from django.db import models # Create your models here. class Score(models.Model): sid = models.CharField(max_len…
比较有用 转自 http://blog.csdn.net/fgf00/article/details/53678205 一.DjangoORM 创建基本类型及生成数据库表结构 1.简介 2.创建数据库 表结构 二.Django ORM基本增删改查 1.表数据增删改查 2.表结构修改 三.Django ORM 字段类型 1.字段类型介绍 2.字段参数介绍 3.Django ORM 外键操作 一.DjangoORM 创建基本类型及生成数据库表结构 1.简介 ORM:关系对象映射.定义一个类自动生成数…
前言:我们知道SQLSERVER清空数据表有两种方式Delete和Truncate,当然两者的不同大家也都知道(不清楚的可以MSDN).不过这个错误“Cannot truncate table  because it is being referenced by a FOREIGN KEY” 相信大家也都遇到过,解决的已解决,未解决的且看下文. 如何解决 开始我以为只要将外键Disable掉就可以了,事实证明是没用的.其实MSDN已经明确告诉了我们: 不能对以下表使用 TRUNCATE TABL…
前面的文章中讲解了外键的基础知识和操作,上一篇文章讲解了sqlalchemy的基本操作.前面两篇文章都是作为铺垫,为下面的文章打好基础.记得初一时第一次期中考试时考的不好,老爸安慰我说:“学习是一个循序渐进的过程”,而我的就是按照这样思路来学习数据库外键.首先是了解外键基础理论,然后是sqlalchemy基本操作,最后才到sqlalchemy操作外键. sqlalchemy体现的外键特性 外键回顾: 外键的出现是因为两张表之间需要有关联,为了保证数据的完整性和唯一性而产生的.有外键时会有两张以上…
多表关系 一对一关系 一对多或多对一关系 多对多关系 MySQL引擎 所谓的MySQL引擎就是数据的存储方式,常用的数据库引擎有以下几种: Myisam与InnoDB引擎之间的区别(面试) ①批量插入与查询速度 Myisam引擎相对于InnoDB引擎,在插入与查询时,速度要略快一些. ②两者的存储方式不同 myisam:在数据表生成时会自动生成3个文件 *.frm :结构文件 *.MYD :数据文件 *.MYI :索引文件 innodb :在数据表生成时其结构如下: innodb在生成时,只会升…
pymsql 外键 本片是以上一篇pymsql操作MySQL的补充,主要演示pymysql的外键操作使用 一.一对一外键关联 1.示意图 2.一对一外键关联示例 2.1.创建表结构,插入数据 from sqlalchemy import create_engine from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Column, Integer, String, DATE, Foreign…
概念 关键字:foreign key,也叫做外键约束! 如果一个实体A的某个字段,刚好指向另一个实体B的主键,那么实体A的这个字段就叫做外键: 所以,简单来说,外键就是本表的某个字段指向外表的主键! 上面的,学生表中的班级字段其实就是一个外键! 其中,被指向的实体集(班级表),叫做主实体集(主表),也叫做父实体集(父表),负责指向的实体集(学生表),叫做从实体集(从表),也叫做子实体集(子表) 作用 外键的意义就是用来约束关系内的实体! 为什么需要有外键约束,因为需要在插入记录的时候,保证其符合…
Django测试环境搭建 ps: 1.pycharm连接数据库都需要提前下载对应的驱动 2.自带的sqlite3对日期格式数据不敏感 如果后续业务需要使用日期辅助筛选数据那么不推荐使用sqlite3 方式1: 任意创建一个py文件,在该文件内书写固定的配置 import os if __name__ == '__main__': os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'djangoProject2.settings') import dj…