大纲

一、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文件:

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

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

settings.py:

  1. INSTALLED_APPS = [
  2. 'django.contrib.admin',
  3. 'django.contrib.auth',
  4. 'django.contrib.contenttypes',
  5. 'django.contrib.sessions',
  6. 'django.contrib.messages',
  7. 'django.contrib.staticfiles',
  8. 'app01', # 这里添加app
  9. ]
  • 执行命令生成表结构

    python manage.py makemigrations # 生成migrations临时文件

     python manage.py migrate # 根据migrations直接生成数据库 

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

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

  • 连接mysql数据库

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

  1. # https://docs.djangoproject.com/en/1.10/ref/settings/#databases 官网文档
  2. # DATABASES = { # sqlite 默认
  3. # 'default': {
  4. # 'ENGINE': 'django.db.backends.sqlite3',
  5. # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
  6. # }
  7. # }
  8. DATABASES = { # mysql
  9. 'default': {
  10. 'ENGINE': 'django.db.backends.mysql',
  11. 'NAME': 'mydatabase',
  12. 'USER': 'mydatabaseuser',
  13. 'PASSWORD': 'mypassword',
  14. 'HOST': '127.0.0.1',
  15. 'PORT': '',
  16. }
  17. }

注意:

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

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

    1. import pymysql
    2. pymysql.install_as_MySQLdb()

二、Django ORM基本增删改查

1、表数据增删改查

urls.py:

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

  1. from app01 import models # 导入models模块
  2. def orm(request):
  3. # 创建数据
  4. # 第一种方式
  5. # models.UserInfo.objects.create(username="root",password="123")
  6. # 第二种方式
  7. # obj = models.UserInfo(username='fzh', password="iajtag")
  8. # obj.save()
  9. # 第三种方式
  10. # dic = {'username':'fgf', 'password':'666'}
  11. # models.UserInfo.objects.create(**dic)
  12.  
  13. # 查询数据
  14. # result = models.UserInfo.objects.all() # 查询所有,为QuerySet类型,可理解成列表
  15. # result = models.UserInfo.objects.filter(username="fgf",password="666") # 列表
  16. # result = models.UserInfo.objects.filter(username="fgf").first() # 对象
  17. # 条件查询。filter 相当于where查询条件,里面的","会组成and条件
  18. # for row in result: # 打印查询到数据。
  19. # print(row.id,row.username,row.password)
  20.  
  21. # 查看QuerySet类型具体做了什么事情,可以: print(result.query)
  22.  
  23. # 删除数据
  24. # models.UserInfo.objects.all().delete() # 删除所有
  25. # models.UserInfo.objects.filter(id=4).delete() # 删除所有
  26.  
  27. # 更新数据
  28. # models.UserInfo.objects.all().update(password=8888)
  29. # models.UserInfo.objects.filter(id=3).update(password=888888)
  30.  
  31. return HttpResponse('orm')

app01/views.py

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

  

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

2、字段参数介绍

  • 数据库中的字段参数
  1. null # 是否可以为空
  2. default # 默认值
  3. primary_key # 主键
  4. db_column # 列名
  5. db_index # 索引(db_index=True)
  6. unique # 唯一索引(unique=True)
  7. unique_for_date # 只对日期索引
  8. unique_for_month # 只对月份索引
  9. unique_for_year # 只对年做索引
  10. auto_now # 创建时,自动生成时间
  11. auto_now_add # 更新时,自动更新为当前时间
  1. # 更新时间不支持这种
  2. obj = UserGroup.objects.filter(id=1).update(caption='CEO')
  3. obj = UserGroup.objects.filter(id=1).first() # 自动更新时间需要这样写
  4. obj.caption = "CEO"
  5. obj.save()

  

  • 以下是只针对admin的字段参数
  1. choices # 作用:1、django admin中显示下拉框;2、避免连表查询
  1. user_type_choices = ( # 数据库只存1、2、3,后面的信息存在内存里。
  2. (1, '超级用户'),
  3. (2, '普通用户'),
  4. (3, '普普通用户'),
  5. )
  6. user_type_id = models.IntegerField(choices=user_type_choices,default=1)
  1. blank # django admin是否可以为空
  2. verbose_name # django admin显示字段中文
  3. editable # django admin是否可以被编辑
  4. error_messages # 错误信息
  5. # error_messages={"required":"密码不能为空",} # 注意必须有逗号
  6. help_text # django admin提示
  7. validators # django form ,自定义错误信息
  8.  
  9. python manage.py createsuperuser # 创建 Django 用户

  

3、Django ORM 外键操作

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

models.py

  • 表关联
  1. class UserGroup(models.Model):
  2. uid = models.AutoField(primary_key=True)
  3. caption = models.CharField(max_length=32,unique=True)
  4. ctime = models.DateTimeField(auto_now_add=True, null=True)
  5. uptime = models.DateTimeField(auto_now=True, null=True)
  6.  
  7. class UserInfo(models.Model):
  8. username = models.CharField(max_length=32,blank=True,verbose_name='用户名')
  9. password = models.CharField(max_length=60, help_text='pwd')
  10. email = models.CharField(max_length=60)
  11. test = models.EmailField(max_length=19,null=True,error_messages={'invalid': '请输入密码',})
  12. # UserInfo表中没有user_group字段,而是 user_group_id 列 值为 uid 数字
  13. user_group = models.ForeignKey("UserGroup",to_field='uid') # 外键关联 **********

  

  • 数据查询
  1. user_list = Userinfo.objects.all() # 获取Userinfo对象
  2. for row in user_list: #
  3. print(row.user_group_id) # 数据库里真实存在的数据
  4. # user_group:代指UserGroup对象。类UserGroup对象里封装了(uid,catption,ctime,uptime)
  5. print(row.user_group.uid) # 通过对象获取uid,和user_group_id一样
  6. print(row.user_group.caption) # 通过对象获取caption

  

  • 创建数据

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

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

转载来源:http://blog.csdn.net/fgf00/article/details/53678205

Django入门4: ORM 数据库操作的更多相关文章

  1. django基础 -- 5. ORM 数据库操作

    一. ORM 对象关系映射 类   ------   表 类对象   ------   记录 类属性   ------   字段 二.  连接数据库配置 1.在  setting.py 文件中重新设置 ...

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

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

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

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

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

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

  5. Django中的ORM进阶操作

    Django中的ORM进阶操作 Django中是通过ORM来操作数据库的,通过ORM可以很easy的实现与数据库的交互.但是仍然有几种操作是非常绕也特别容易混淆的.于是,针对这一块,来一个分类总结吧. ...

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

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

  7. Django框架 之 ORM查询操作详解

    Django框架 之 ORM查询操作详解 浏览目录 一般操作 ForeignKey操作 ManyToManyField 聚合查询 分组查询 F查询和Q查询 事务 Django终端打印SQL语句 在Py ...

  8. 循序渐进Python3(十二) --2--  web框架之django简单实现oracle数据库操作

    在 Django 中构建 Oracle 数据库支持的 Web 应用程序 了解如何配置 Django 以便与 Oracle 数据库交互,并使用 ORM 进行数据库连接.             产能在软 ...

  9. Django ----- app 和 ORM的操作和介绍

    创建APP ORM 介绍 ORM的操作 说明一下 GET 和 POST 的区别: , GET ①获取一个页面 ②提交数据 数据显示在URL ?user=alex&pwd=alexdsb ,PO ...

随机推荐

  1. 1047 Student List for Course (25分)

    Zhejiang University has 40,000 students and provides 2,500 courses. Now given the registered course ...

  2. (js描述的)数据结构[双向链表](5)

    (js描述的)数据结构[双向链表](5) 一.单向链表的缺点 1.只能按顺序查找,即从上一个到下一个,不能反过来. 二.双向链表的优点 1.可以双向查找 三.双向链表的缺点 1.结构较单向链表复杂. ...

  3. Java第三十天,I/O操作

    一.基本概念 输入输出一般是相对与内存.CPU寄存器.当前进程来说的 输入:从硬盘.键盘等外部设备读取数据到内存.当前进程或CPU寄存器中 输出:利用当前进程将数据写入到硬盘.终端显示屏等外部设备中 ...

  4. N皇后问题 回溯非递归算法 C++实现2

    运行结果 代码如下 #include <bits/stdc++.h> using namespace std; ; const char *LINE32 = "--------- ...

  5. Linux下安装Redis4.0版本(简便方法)

    Redis介绍: Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key - value 缓存产品有以下三个特点: Redis支持数据的持久 ...

  6. ORA-0245

    经常有客户报错ORA-0245 1.11.2 rac环境, rman存在snap控制文件路径,默认是文件系统[非共享,导致备份控制文件报错] 解决方法:将snap路径配置到ASM磁盘组共享路径[nfs ...

  7. asp.net core web api + Element-UI的Vue管理后台

    后端:asp.net core web api + EF Core 前端:VUE + Element-UI+ Node环境的后台管理系统. 线上地址:http://www.wangjk.wang/ 密 ...

  8. React AntDesign 引入css

    React项目是用umi脚手架搭建的AntDesign,用到一个第三方表格组件Jexcel,npm install 之后组件的样式加载不上,犯了愁,翻阅各种资料,踏平两个小坑. 大家都知道,安装完成的 ...

  9. sftp的用法

    linux sftp远程连接命令 sftp -oPort=60001 root@192.168.0.254 使用-o选项来指定端口号. -oPort=远程端口号 sftp> get /var/w ...

  10. Prometheus监控 Redis & Redis Cluster 说明

    说明 在前面的Prometheus + Grafana 部署说明之「安装」文章里,大致介绍说明了Prometheus和Grafana的一些安装使用,现在开始如何始部署Prometheus+Grafan ...