在django项目中,其自带了ORM(Object Relation Mapping)对象关系映射框架,我们在django项目下app的models模块下对类进行操作,通过ORM会将我们对类的操作转化为具体的数据库sql语句,继而实现对数据库的操作。

1. 数据模型类的简单创建:

在django项目下的app的models模块下:

  注意:实现orm映射的前提是创建的类必须继承自django.db包下的models模块的Model类。

#  1.导入模块

from django.db import models

# 2.创建类,继承  --> 对应数据库操作是创建表,表名字为“app名+类名”, 名字自动全部转换为小写;

# sql语句: create table book_app_bookinfo(字段信息);

class BookInfo(models.Model):

  pass

  '''

  也可通过元选项自定义在数据库中创建的表名,意义不大。

  class Meta:

    db_table = 'my_tablename'

  '''

# 3.设计好了数据模型的类,即相当于创建好了表。但是我们发现上面这张表设计的时候并没有设计表的字段,这显然是不对的,下面进行字段的设计

class BookInfo(moels.Model):

  # 设计字段名为bname, 约束字段类型为char,最大长度为20

  bname = models.CharField(max_length=20)

  bisDelete = models.BooleanField(default=false)  # 逻辑删除,默认false

# 4.模型类已经完成,再将models模块的内容进行迁移即可执行ORM转换的sql语句,对数据库进行对应操作

在命令行下,进入当前django项目所在的(虚拟)环境,执行以下:

  $ django-admin mkmigrations      # 生产迁移文件(在django项目的app目录下的migrations目录下可看到生产了对应的迁移文件)

  $ django-admin migrate        # 执行迁移(即执行了对应的sql语句)

查看数据库,可以看到当前的数据库中新增了一张表book_app_bookinfo,主键id我们并没有设计,会自动给我们设计好。

2.数据模型类的映射关系:

  app名:book_app

  类名:BookInfo   -->表名:book_app_bookinfo

  类属性创建时的方法:CharField/BooleanField  -->字段属性: char/bool

  方法的参数选项:max_length/default  -->字段属性的约束选项

  [字段名] = models.[字段属性]([属性约束选项])

3.常用字段属性:

  AutoField  -->自动增长的IntegerField,通常不指定,django会自动创建,auto_increment

  CharField  -->字符串类型,必须有(max_length=[xx])参数

  BooleanField  -->布尔类型,不能为空(default=[ture/false])

  DateField  -->日期类型,参数:auto_now:自动设置为最后一次修改的时间戳  auto_now_add:自动设置为第一次创建时的时间戳

  DateTimeField/TimeField  -->日期类型,参数同DateField

  SamllIntegerField  -->整数类型,对应tinyint/smallint/int/bigint

  Decimal  -->小数类型,必须指定整数位和小数位(例: (max_digits=None,decimal_places=None))

  BinaryField  -->二进制类型

  FloatField  -->浮点类型

  

4.常用字段属性选项:

  primary_key  -->默认为False,True表示为主键,一般AutoField使用

  null  -->默认为False,True表示该字段可以为空(添加数据时该字段可以不设置)

  blank  -->默认为False,True表示添加数据时该字段的值可以为空值

  default  -->设置默认值

  max_length  -->最大长度

Django项目的ORM操作之--数据模型类创建的更多相关文章

  1. Django项目的ORM操作之--模型类数据查询

    1.查询基本格式及理解: 类名.objects.[查询条件] 例如我们要查询数据库中一张表(bookinfo)的所有数据,sql语句为:select * from bookinfo, 对应模型类的操作 ...

  2. Django学习之ORM操作

    一.一般操作 二.必知必会13条 返回QuerySet对象的方法有 特殊的QuerySet 返回具体对象的 返回布尔值的方法有 返回数字的方法 三.单表查询之神奇的双下划线 四.ForeignKey操 ...

  3. Django专题之ORM操作2

    Django ORM操作   目录 一般操作 看专业的官网文档,做专业的程序员! 回到顶部 必知必会13条 <1> all(): 查询所有结果 <2> get(**kwargs ...

  4. Python/Django(CBV/FBV/ORM操作)

    Python/Django(CBV/FBV/ORM操作) CBV:url对应的类(模式) ##====================================CBV操作============ ...

  5. Django - 表与ORM操作

    Django - 表与ORM操作 一. 模板语言 模板中也有自己的语言, 该语言可以实现数据展示 - {{ 变量 }} - 循环 {% for i in all_publisher %} {{ for ...

  6. 跨过Nginx上基于uWSGI部署Django项目的坑

    先说说他们的关系,Nginx和uWSGI都是Web服务器,Nginx负责静态内容,uWSGI负责Python这样的动态内容,二者配合共同提供Web服务以实现提高效率和负载均衡等目的.uWSGI实现了多 ...

  7. 初学Django基础02 ORM操作

    django的ORM操作 之前我们知道了models.py这个文件,这个文件是用来读取数据结构的文件,每次操作数据时都走这个模块 常用字段 AutoField int自增列,必须填入参数 primar ...

  8. Django 模型层 ORM 操作

    运行环境 1. Django:2.1.3 version 2. PyMysql: 0.9.3 version 3. pip :19.0.3 version 4. python : 3.7 versio ...

  9. docker笔记(3) ------Django项目的docker部署

    2019-01-12   14:23:18 django容器连接到mysql_server容器分析:原myblog项目使用sqlit3数据库,使用mysql容器前需要在django中加入pymysql ...

随机推荐

  1. 20145314郑凯杰《信息安全系统设计基础》第6周学习总结 part A

    第4章 处理器体系结构 part 1 本部分对改章节的知识点进行总结: 一个处理器支持的指令和指令的字节级编码称为它的指令集体系结构(ISA). 不同的出路器有不同的ISA. ISA模型看上去应该是顺 ...

  2. 20145314郑凯杰 《Java程序设计》课程总结

    20145314郑凯杰 <Java程序设计>课程总结 每周读书笔记链接汇总 ①寒假预习--"helloworld" ②第一周读书笔记 ③第二周读书笔记 ④第三周读书笔记 ...

  3. 20145329 《Java程序设计》实验五总结

    实验内容: 1.用老师代码编写,实现服务器与客户端. 2.客户端与服务器连接 3.客户端中输入明文,利用DES算法加密,DES的秘钥用RSA公钥密码中服务器的公钥加密,计算明文的Hash函数值,一起传 ...

  4. 20145335郝昊 Java学习心得 密码学代码复写

    20145335郝昊 Java学习心得 密码学代码复写 本学期我们学习了现代密码学这门课程,在上课的时候接触到了很多种类型的密码体制,对于一些典型很通用的密码体制有自己的学习和设计.不论是从密码体制还 ...

  5. js事件委托篇(附js一般写法和js、jq事件委托写法)

    参考: jQuery代码优化:事件委托篇 使用该技术能让你避免对特定的每个节点添加事件监听器:相反,事件监听器被添加在他们的父元素上,事件监听器会分析从子元素上冒泡上来的事件,并找到是哪个子元素事件. ...

  6. php-fpm 信号

    使用信号之前,需要先确保php-fpm.conf 里面有配置pid,默认是被注释掉的. ;pid = run/php-fpm.pid 文件在 php安装目录/var/run/php-fpm.pid 信 ...

  7. centos7下使用yum安装mysql数据库

    CentOS7的yum源中默认是没有mysql的.为了解决这个问题,我们要先下载mysql的repo源. 1.下载并安装MySQL官方的 Yum Repository wget -i -c http: ...

  8. 记数排序 & 桶排序 & 基数排序

    为什么要写这样滴一篇博客捏...因为一个新初一问了一道水题,结果就莫名其妙引起了战斗. 然后突然发现之前理解的桶排序并不是真正的桶排序,所以写一篇来区别下这三个十分相似的排序辣. 老年菜兔的觉醒!!! ...

  9. LeetCode——Sort List

    Question Sort a linked list in O(n log n) time using constant space complexity. Solution 分析,时间复杂度要求为 ...

  10. PHP Fatal error: Call to undefined function imagecreatetruecolor()

    是因为没有安装gd apt-get install libgd2-xpm-dev* apt-get install php5-gd