大纲

一、DjangoORM 创建基本类型及生成数据库表结构 
1、简介 
2、创建数据库 表结构 
二、Django ORM基本增删改查 
1、表数据增删改查 
2、表结构修改 
三、Django ORM 字段类型 
1、字段类型介绍 
2、字段参数介绍 
3、Django ORM 外键操作

一、DjangoORM 创建基本类型及生成数据库表结构

1、简介

ORM:关系对象映射。定义一个类自动生成数据库的表结构。

创建数据库的时候,一般有以下几种常用数据类型:数字、字符串以及时间。

ORM分为两种:

  • DB First 数据库里先创建数据库表结构,根据表结构生成类,根据类操作数据库
  • Code First 先写代码,执行代码创建数据库表结构

主流的orm都是code first。django 的orm也是code first,所以学的时候,本质就分为两块:

  • 根据类自动创建数据库表
  • 根据类对数据库表中的数据进行各种操作

2、创建数据库 表结构

  • 先写类:

app下models.py文件:

from django.db import models

class UserInfo(models.Model):  # 必须继承models.Model
# 不写则,django默认创建ID列,自增,主键
# 用户名列,字符串类型,指定长度
username = models.CharField(max_length=32)
password = models.CharField(max_length=64)
  • 注册APP

执行命令 python manage.py makemigrations,会提示 No changes detected,这是因为:执行命令时会找所有models,但是django不知道找哪个,所有需要指定一下。

settings.py,

INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01', # 这里添加app
]
  • 执行命令生成表结构
python manage.py  makemigrations    # 生成migrations临时文件
python manage.py migrate # 根据migrations直接生成数据库
 

执行后,从migrations便会产生操作记录。生成数据库,默认情况下用的sqlite3。可以用navicat等软件直接打开。

db.sqlite3里面包含缓存、session、cookie、静态文件以及后台管理。像咱们创建的表名叫:app01_userinfo

  • 连接mysql数据库

如果不使用sqlite,使用MySQL数据库。代码不用改、命令也不用改,只需要改下配置文件。

# https://docs.djangoproject.com/en/1.10/ref/settings/#databases  官网文档
# DATABASES = { # sqlite 默认
# 'default': {
# 'ENGINE': 'django.db.backends.sqlite3',
# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
# }
# }
DATABASES = { # mysql
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'mydatabase',
'USER': 'mydatabaseuser',
'PASSWORD': 'mypassword',
'HOST': '127.0.0.1',
'PORT': '',
}
}

注意:

  • 数据库名django不能创建,需要自己提前创建

  • Django默认使用MySQLdb模块链接mysql,但python3现在还没有MySQLdb,所以改为用pymysql去连。在project项目名下的__init__.py里面

import pymysql
pymysql.install_as_MySQLdb()

二、Django ORM基本增删改查

1、表数据增删改查

urls.py

url(r'^orm/', views.orm),

app01/views.py

from app01 import models  # 导入models模块
def orm(request):
# 创建数据
# 第一种方式
# models.UserInfo.objects.create(username="root",password="123")
# 第二种方式
# obj = models.UserInfo(username='fzh', password="iajtag")
# obj.save()
# 第三种方式
# dic = {'username':'lgeng', 'password':'666'}
# models.UserInfo.objects.create(**dic) # 查询数据
# result = models.UserInfo.objects.all() # 查询所有,为QuerySet类型,可理解成列表
# result = models.UserInfo.objects.filter(username="lgeng",password="666") # 列表
# result = models.UserInfo.objects.filter(username="lgeng").first() # 对象
# 条件查询。filter 相当于where查询条件,里面的","会组成and条件
# for row in result: # 打印查询到数据。
# print(row.id,row.username,row.password) # 查看QuerySet类型具体做了什么事情,可以: print(result.query) # 删除数据
# models.UserInfo.objects.all().delete() # 删除所有
# models.UserInfo.objects.filter(id=4).delete() # 删除所有 # 更新数据
# models.UserInfo.objects.all().update(password=8888)
# models.UserInfo.objects.filter(id=3).update(password=888888) return HttpResponse('orm')

2、表结构修改

  • 修改列

把最初定义的类中字段 password = models.CharField(max_length=64) 改为 password = models.CharField(max_length=60)。重新执行 python manage.py makemigrationspython manage.py migrate,则数据表结构更改了。如果列内内容超过定义大小,则数据就丢了。

  • 增加一列

类中增加一列,执行命令,会有提示信息,因为默认情况下是不允许为空的。这里提供两个选项。

  1. 输入一个值,新增列已存在的行默认加上输入的内容。
  2. email = models.CharField(max_length=32, null=True),允许为空

查看表结构变化时,刷新看不出来,需要重新打开表看效果。

  • 删除列

类内删掉相应的字段,执行命令即可。

三、Django ORM 字段类型

1、字段类型介绍

Django ORM 字段类型中,有CharField、EmailField、URLField、GenericIPAddressField等,实际上在数据库里都是字符串。不能做检查语法,做不了验证。那这个有什么用呢?

这些是给Django 的 admin 用的。在admin那个网页上做验证。如果不用admin,那那些都是字符串,效果都一样。

自定义自增列models.AutoField(primary_key=True)

1、models.AutoField  自增列 = int(11)
  如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自定义一个自增列,必须将给列设置为主键 primary_key=True。
2、models.CharField  字符串字段
  必须 max_length 参数
3、models.BooleanField  布尔类型=tinyint(1)
  不能为空,Blank=True
4、models.ComaSeparatedIntegerField  用逗号分割的数字=varchar
  继承CharField,所以必须 max_lenght 参数
5、models.DateField  日期类型 date
  对于参数,auto_now = True 则每次更新都会更新这个时间;auto_now_add 则只是第一次创建添加,之后的更新不再改变。
6、models.DateTimeField  日期类型 datetime
  同DateField的参数
7、models.Decimal  十进制小数类型 = decimal
  必须指定整数位max_digits和小数位decimal_places
8、models.EmailField  字符串类型(正则表达式邮箱) =varchar
  对字符串进行正则表达式
9、models.FloatField  浮点类型 = double
10、models.IntegerField  整形
11、models.BigIntegerField  长整形
  integer_field_ranges = {
    'SmallIntegerField': (-32768, 32767),
    'IntegerField': (-2147483648, 2147483647),
    'BigIntegerField': (-9223372036854775808, 9223372036854775807),
    'PositiveSmallIntegerField': (0, 32767),
    'PositiveIntegerField': (0, 2147483647),
  }
12、models.IPAddressField  字符串类型(ip4正则表达式)(已弃用,用13、)
13、models.GenericIPAddressField  字符串类型(ip4和ip6是可选的)
  参数protocol可以是:both、ipv4、ipv6
  验证时,会根据设置报错
14、models.NullBooleanField  允许为空的布尔类型
15、models.PositiveIntegerFiel  正Integer
16、models.PositiveSmallIntegerField  正smallInteger
17、models.SlugField  减号、下划线、字母、数字
18、models.SmallIntegerField  数字
  数据库中的字段有:tinyint、smallint、int、bigint
19、models.TextField  字符串=longtext
20、models.TimeField  时间 HH:MM[:ss[.uuuuuu]]
21、models.URLField  字符串,地址正则表达式
22、models.BinaryField  二进制
23、models.ImageField 图片
24、models.FilePathField 文件

如上那么多的字段,可大致分为 字符串、数字、时间、二进制、自增(primary_key=True)几类。

2、字段参数介绍

  • 数据库中的字段参数
null                # 是否可以为空
default # 默认值
primary_key # 主键
db_column # 列名
db_index # 索引(db_index=True)
unique # 唯一索引(unique=True)
unique_for_date # 只对日期索引
unique_for_month # 只对月份索引
unique_for_year # 只对年做索引
auto_now # 创建时,自动生成时间
auto_now_add # 更新时,自动更新为当前时间
# 更新时间(auto_now)不支持这种
obj = UserGroup.objects.filter(id=1).update(caption='CEO')
obj = UserGroup.objects.filter(id=1).first() # 自动更新时间需要这样写
obj.caption = "CEO"
obj.save()
  • 以下是只针对admin的字段参数
choices             # 作用:1、django admin中显示下拉框;2、避免连表查询
user_type_choices = (  # 数据库只存1、2、3,后面的信息存在内存里。
(1, '超级用户'),
(2, '普通用户'),
(3, '普普通用户'),
)
user_type_id = models.IntegerField(choices=user_type_choices,default=1)
blank              # django admin是否可以为空
verbose_name # django admin显示字段中文
editable # django admin是否可以被编辑
error_messages # 错误信息
# error_messages={"required":"密码不能为空",} # 注意必须有逗号
help_text # django admin提示
validators # django form ,自定义错误信息 python manage.py createsuperuser # 创建 Django 用户

3、Django ORM 外键操作

连表关系之一对多,models.ForeignKey(ColorDic)

models.py

  • 表关联
class UserGroup(models.Model):
uid = models.AutoField(primary_key=True)
caption = models.CharField(max_length=32,unique=True)
ctime = models.DateTimeField(auto_now_add=True, null=True)
uptime = models.DateTimeField(auto_now=True, null=True) class UserInfo(models.Model):
username = models.CharField(max_length=32,blank=True,verbose_name='用户名')
password = models.CharField(max_length=60, help_text='pwd')
email = models.CharField(max_length=60)
test = models.EmailField(max_length=19,null=True,error_messages={'invalid': '请输入密码',})
# UserInfo表中没有user_group字段,而是 user_group_id 列 值为 uid 数字
user_group = models.ForeignKey("UserGroup",to_field='uid') # 外键关联 **********
  • 数据查询
user_list = models.Userinfo.objects.all()  # 获取Userinfo对象
for row in user_list: #
print(row.user_group_id) # 数据库里真实存在的数据
# user_group:代指UserGroup对象。类UserGroup对象里封装了(uid,catption,ctime,uptime)
print(row.user_group.uid) # 通过对象获取uid,和user_group_id一样
print(row.user_group.caption) # 通过对象获取caption
  • 创建数据

UserInfo表创建数据,怎么写呢?

models.UserInfo.objects.create(
username='root1',
password='',
email="asdfasdf",
test="asdfasdf",
# 第一种方式:再次查询数据库,不推荐
# user_group = models.UserGroup.objects.filter(id=1).first()
# 第二种方式:通过 外键字段_id
user_group_id = 1
)

转载请务必保留此出处:http://www.cnblogs.com/lgeng/articles/7364356.html

<!-- EDD  -->

《版权说明》: 本文转自 -- http://blog.csdn.net/fgf0/article/details/53678205

Django(三) ORM 数据库操作的更多相关文章

  1. Django【第5篇】:Django之ORM数据库操作

    django之ORM数据库操作 一.ORM介绍 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录-------- ...

  2. django之ORM数据库操作

    一.ORM介绍 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录----------------->类实例 ...

  3. Django框架----ORM数据库操作

    一.ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用 ...

  4. Django框架(八) Django之ORM数据库操作

    创建模型 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是一对一的关系( ...

  5. Django框架----ORM数据库操作注意事项

    1.多对多的正向查询 class Class(models.Model): name = models.CharField(max_length=32,verbose_name="班级名&q ...

  6. Django 2.0 学习(16):Django ORM 数据库操作(下)

    Django ORM数据库操作(下) 一.增加表记录 对于表单有两种方式: # 方式一:实例化对象就是一条表记录france_obj = models.Student(name="海地&qu ...

  7. Django 2.0 学习(14):Django ORM 数据库操作(上)

    Django ORM 数据库操作(上) ORM介绍 映射关系: 数据库表名 ---------->类名:数据库字段 ---------->类属性:数据库表一行数据 ----------&g ...

  8. golang学习笔记16 beego orm 数据库操作

    golang学习笔记16 beego orm 数据库操作 beego ORM 是一个强大的 Go 语言 ORM 框架.她的灵感主要来自 Django ORM 和 SQLAlchemy. 目前该框架仍处 ...

  9. 关于Django中的数据库操作API之distinct去重的一个误传

    转载自http://www.360doc.com/content/18/0731/18/58287567_774731201.shtml django提供的数据库操作API中的distinct()函数 ...

  10. 关于Django中ORM数据库迁移的配置

    Django中ORM数据库迁移配置 1,若想将模型转为mysql数据库中的表,需要在settings中配置: DATABASES = { 'default': { 'ENGINE': 'django. ...

随机推荐

  1. Android 性能测试优质实践汇总

    这两天把testerhome上的关于Android 性能测试的精品文章看了一遍,很有收获,学习到了Android 性能测试该关注的一些细节.我所说的“精品”是指对我自己有启发的文章,可以被自己运用起来 ...

  2. Vue父子组件传参新写法

    以前我在写接受自定义事件是这么写的: 后来我在官网看到这样一种说法:可以用$event代替emit事件传入的参数,于是我写成了这样: 直到昨天Vetur更新,给我报了这么一个错误: 报错原因:事件不能 ...

  3. Flink从入门到放弃(入门篇2)-本地环境搭建&构建第一个Flink应用

    戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...

  4. WinDbg调试C#技巧,解决CPU过高、死锁、内存爆满

    软件安装 安装问题:执行 .loadby sos clr 命令无效 解决办法: .load C:\Windows\Microsoft.NET\Framework64\v4.0.30319\SOS.dl ...

  5. 101 - kube-scheduler源码分析 - k8s源码组织结构概览

    ps:本来应该先发这一篇,再开始讲cobra的,昨天不小心先把 cobra发出去了,今天补上源码概览~ 如上,我们下载好后切换到1.10版本的分支,项目目录结构是这样的(目录部分).有很多,我们先不纠 ...

  6. sql server 生成数据库字典 sql语句

    SELECT TOP 100 PERCENT --a.id,          CASE WHEN a.colorder = 1 THEN d.name ELSE '' END AS 表名,      ...

  7. socket,模拟服务器、客户端通信

    服务器代码: using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;u ...

  8. JS里charCodeAt()和fromCharCode()方法拓展应用:加密与解密

    JS实现客户端的网页加密解密技术,可用作选择性隐蔽展示.当然客户端的加密安全度是不能与服务器相提并论,肯定不能用于密码这类内容的加密,但对于一般级别的内容用作展示已经够了. JS加密与解密的解决方案有 ...

  9. ASP.NET Core的JWT的实现(自定义策略形式验证).md

    既然选择了远方,便只顾风雨兼程 __ HANS许 在上篇文章,我们讲了JWT在ASP.NET Core的实现,基于中间件来实现.这种方式有个缺点,就是所有的URL,要嘛需要验证,要嘛不需要验证,没有办 ...

  10. 008. 阻塞&非阻塞、同步&异步

    阻塞 非阻塞:关注的对象是调用者: 阻塞:调用者发起调用后,处于等待状态,直到该调用有返回: 非阻塞:调用者发起调用后,不需要等待返回,可以往下执行: 同步 异步:  关注的对象是被调用者: 同步:服 ...