ORM

ORM

ORM 是’对象-关系-映射‘的简称主要任务

*1根据对象的类型生成表结构

*2将对象、列表的操作,转换为sql语句

*3将sql查询到的结果转换为对象、列表

这极大的减轻了开发人员的工作量,不需要面对数据变更而导致的无效劳动。

使用mysql数据库

*在mysql中创建数据库

create databases test2 charset=utf8

*打开settings.py文件,修改DATABASES项

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.mysql',

'NAME': 'test2',

'USER': '用户名',

'PASSWORD': '密码',

'HOST': '数据库服务器ip,本地可以使用localhost',

'PORT': '端口,默认为3306',

}

}

*注意:需要在我们得站点得init文件

import pymysql

pymysql.install_as_MySQLdb()

字段类型

AutoField:一个根据实际ID自动增长的IntegerField,通常不指定

如果不指定,一个主键字段将自动添加到模型中

BooleanField:true/false 字段,此字段的默认表单控制是CheckboxInput

NullBooleanField:支持null、true、false三种值

CharField(max_length=字符长度):字符串,默认的表单样式是 TextInput

TextField:大文本字段,一般超过4000使用,默认的表单控件是Textarea

IntegerField:整数

DecimalField(max_digits=None, decimal_places=None):使用python的Decimal实例表示的十进制浮点数

DecimalField.max_digits:位数总数

DecimalField.decimal_places:小数点后的数字位数

FloatField:用Python的float实例来表示的浮点数

DateField([auto_now=False, auto_now_add=False]):使用Python的datetime.date实例表示的日期

参数DateField.auto_now:每次保存对象时,自动设置该字段为当前时间,用于”最后一次修改”的时间戳,它总是使用当前日期,默认为false

参数DateField.auto_now_add:当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为false

该字段默认对应的表单控件是一个TextInput. 在管理员站点添加了一个JavaScript写的日历控件,和一个“Today”的快捷按钮,包含了一个额外的invalid_date错误消息键

auto_now_add, auto_now, and default 这些设置是相互排斥的,他们之间的任何组合将会发生错误的结果

TimeField:使用Python的datetime.time实例表示的时间,参数同DateField

DateTimeField:使用Python的datetime.datetime实例表示的日期和时间,参数同DateField

FileField:一个上传文件的字段

ImageField:继承了FileField的所有属性和方法,但对上传的对象进行校验,确保它是个有效的image

字段的选择

通过字段选项,可以实现对字段的约束

在字段对象时通过关键字参数指定

null:如果为True,Django 将空值以NULL 存储到数据库中,默认值是 False

blank:如果为True,则该字段允许为空白,默认值是 False

对比:null是数据库范畴的概念,blank是表单验证证范畴的

db_column:字段的名称,如果未指定,则使用属性的名称

db_index:若值为 True, 则在表中会为此字段创建索引

default:默认值

primary_key:若为 True, 则该字段会成为模型的主键字段

unique:如果为 True, 这个字段在表中必须有唯一值

元选项

在模型类中定义类Meta,用于设置元信息

元信息db_table:定义数据表名称,推荐使用小写字母,数据表的默认名称

_

ordering:对象的默认排序字段,获取对象的列表时使用,接收属性构成的列表

class BookInfo(models.Model):

...

class Meta():

ordering = ['id']**strong text**

字符串前加-表示倒序,不加-表示正序

class BookInfo(models.Model):

...

class Meta():

ordering = ['-id']

排序会增加数据库的开销

类的属性

objects:是Manager类型的对象,用于与数据库进行交互

当定义模型类时没有指定管理器,则Django会为模型类提供一个名为objects的管理器

查询集

返回查询集的方法,称为过滤器

all()

filter()

exclude()

order_by()

values():一个对象构成一个字典,然后构成一个列表返回

filter(键1=值1,键2=值2)

等价于

filter(键1=值1).filter(键2=值2)

get():返回单个满足条件的对象

如果未找到会引发”模型类.DoesNotExist”异常 *

如果多条被返回,会引发”模型类.MultipleObjectsReturned”异常

count():返回当前查询的总条数

first():返回第一个对象

last():返回最后一个对象

exists():判断查询集中是否有数据,如果有则返回True

限制查询集

查询集返回列表,可以使用下标的方式进行限制,等同于sql中的limit和offset子句

注意:不支持负数索引

使用下标后返回一个新的查询集,不会立即执行查询

如果获取一个对象,直接使用[0],等同于[0:1].get(),但是如果没有数据,[0]引发IndexError异常,[0:1].get()引发DoesNotExist异常

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,591评论 18 139
  • 点击查看原文 Web SDK 开发手册 SDK 概述 网易云信 SDK 为 Web 应用提供一个完善的 IM 系统...
    layjoy阅读 13,653评论 0 15
  • 原文:https://my.oschina.net/liuyuantao/blog/751438 查询集API 参...
    阳光小镇少爷阅读 3,809评论 0 8
  • 在多数人看来,小猫可能不如小狗招人喜欢,可能因为它们不够忠诚又缺点多多,馋猫、懒猫、病猫、好奇害死猫……这些专...
    七散阅读 338评论 1 0
  • 读书笔记: 古代硬币有正反两面,其中一面是国王的头像,代表着世俗的权力;另一面则是上帝的形象。 三条准则:尊重友好...
    梅哩哆阅读 727评论 0 0