Django-Model数据库操作(增删改查、连表结构)详解


Posted in Python onJuly 17, 2019

一、数据库操作

1、创建model表

Django-Model数据库操作(增删改查、连表结构)详解

基本结构

from django.db import models
 
class userinfo(models.Model):
 #如果没有models.AutoField,默认会创建一个id的自增列
 name = models.CharField(max_length=30)
 email = models.EmailField()
 memo = models.TextField()

更多字段:

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

更多参数

1、null=True
数据库中字段是否可以为空
2、blank=True

django的Admin中添加数据时是否可允许空值
3、primary_key =False

主键,对AutoField设置主键后,就会代替原来的自增 id 列
4、auto_now 和 auto_now_add

auto_now 自动创建---无论添加或修改,都是当前操作的时间

auto_now_add 自动创建---永远是创建时的时间
5、choices
GENDER_CHOICE =(
(u'M', u'Male'),
(u'F', u'Female'),
)
gender = models.CharField(max_length=2,choices = GENDER_CHOICE)
6、max_length
7、default
默认值
8、verbose_name
Admin中字段的显示名称
9、name|db_column
数据库中的字段名称
10、unique=True
不允许重复
11、db_index =True
数据库索引
12、editable=True
在Admin里是否可编辑
13、error_messages=None
错误提示
14、auto_created=False
自动创建
15、help_text
在Admin中提示帮助信息
16、validators=[]
17、upload-to

2、注册APP,settings添加app

3、生成相应的表

python manage.py makemigrations
 python manage.py migrate

Django-Model数据库操作(增删改查、连表结构)详解

4、admin后台注册表

Django-Model数据库操作(增删改查、连表结构)详解

python manage.py createsuperuser 创建用户

后台可以管理,添加数据

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

对数据进行增删改查

models.UserInfo.objects.all()
models.UserInfo.objects.all().values('user') #只取user列
models.UserInfo.objects.all().values_list('id','user') #取出id和user列,并生成一个列表
models.UserInfo.objects.get(id=1)
models.UserInfo.objects.get(user='yangmv')

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

成功获取数据

Django-Model数据库操作(增删改查、连表结构)详解


models.UserInfo.objects.create(user='yangmv',pwd='123456')

或者

obj = models.UserInfo(user='yangmv',pwd='123456')
obj.save()

或者

dic = {'user':'yangmv','pwd':'123456'}
models.UserInfo.objects.create(**dic)

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解


models.UserInfo.objects.filter(user='yangmv').delete()

Django-Model数据库操作(增删改查、连表结构)详解


models.UserInfo.objects.filter(user='yangmv').update(pwd='520')

或者

obj = models.UserInfo.objects.get(user='yangmv')
obj.pwd = '520'
obj.save()

常用方法

# 获取个数
 #
 # models.Tb1.objects.filter(name='seven').count()
 # 大于,小于
 #
 # models.Tb1.objects.filter(id__gt=1) # 获取id大于1的值
 # models.Tb1.objects.filter(id__lt=10) # 获取id小于10的值
 # models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值
 # in
 #
 # models.Tb1.objects.filter(id__in=[11, 22, 33]) # 获取id等于11、22、33的数据
 # models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in
 # contains
 #
 # models.Tb1.objects.filter(name__contains="ven")
 # models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
 # models.Tb1.objects.exclude(name__icontains="ven")
 # range
 #
 # models.Tb1.objects.filter(id__range=[1, 2]) # 范围bettwen and
 # 其他类似
 #
 # startswith,istartswith, endswith, iendswith,
 # order by
 #
 # models.Tb1.objects.filter(name='seven').order_by('id') # asc
 # models.Tb1.objects.filter(name='seven').order_by('-id') # desc
 # limit 、offset
 #
 # models.Tb1.objects.all()[10:20]
 # group by
 from django.db.models import Count, Min, Max, Sum
 # models.Tb1.objects.filter(c1=1).values('id').annotate(c=Count('num'))
 # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"

二、常用字段

models.DateTimeField    日期类型 datetime

参数,

auto_now = True :则每次更新都会更新这个时间

auto_now_add 则只是第一次创建添加,之后的更新不再改变。

class UserInfo(models.Model):
 name = models.CharField(max_length=32)
 ctime = models.DateTimeField(auto_now=True)
 uptime = models.DateTimeField(auto_now_add=True)
from web import models
def home(request):
 models.UserInfo.objects.create(name='yangmv')
 after = models.UserInfo.objects.all()
 print after[0].ctime
 return render(request, 'home/home.html')

Django-Model数据库操作(增删改查、连表结构)详解

表结构的修改

表结构修改后,原来表中已存在的数据,就会出现结构混乱,makemigrations更新表的时候就会出错

解决方法:

1、新增加的字段,设置允许为空。生成表的时候,之前数据新增加的字段就会为空。(null=True允许数据库中为空,blank=True允许admin后台中为空)

2、新增加的字段,设置一个默认值。生成表的时候,之前的数据新增加字段就会应用这个默认值

Django-Model数据库操作(增删改查、连表结构)详解

执行makemigrations, migrate 后。老数据会自动应用新增加的规则

Django-Model数据库操作(增删改查、连表结构)详解

models.ImageField    图片

models.GenericIPAddressField     IP

ip = models.GenericIPAddressField(protocol="ipv4",null=True,blank=True)

img = models.ImageField(null=True,blank=True,upload_to="upload")

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

数据库中保存的只是图片的路径

Django-Model数据库操作(增删改查、连表结构)详解

常用参数

选择下拉框 choices

class UserInfo(models.Model):
 USER_TYPE_LIST = (
 (1,'user'),
(2,'admin'),
)
 user_type = models.IntegerField(choices=USER_TYPE_LIST,default=1)

Django-Model数据库操作(增删改查、连表结构)详解

2、连表结构

  • 一对多:models.ForeignKey(其他表)
  • 多对多:models.ManyToManyField(其他表)
  • 一对一:models.OneToOneField(其他表)

应用场景:

  • 一对多:当一张表中创建一行数据时,有一个单选的下拉框(可以被重复选择)
  • 例如:创建用户信息时候,需要选择一个用户类型【普通用户】【金牌用户】【铂金用户】等。
  • 多对多:在某表中创建一行数据是,有一个可以多选的下拉框
  • 例如:创建用户信息,需要为用户指定多个爱好
  • 一对一:在某表中创建一行数据时,有一个单选的下拉框(下拉框中的内容被用过一次就消失了
  • 例如:原有含10列数据的一张表保存相关信息,经过一段时间之后,10列无法满足需求,需要为原来的表再添加5列数据

一对多:

class Game(models.Model):
 gname = models.CharField(max_length=32)
 
class Host(models.Model):
 hostname = models.CharField(max_length=32)
 game = models.ForeignKey('Game')

这是Game表,里面有3个业务

Django-Model数据库操作(增删改查、连表结构)详解

这是主机表,可以通过外键,对应到Game表的业务的ID

Django-Model数据库操作(增删改查、连表结构)详解

多对多:

class UserGroup(models.Model):
 group_name = models.CharField(max_length=16)
 
class User(models.Model):
 name = models.CharField(max_length=16)
 sex = models.CharField(max_length=16)
 email = models.EmailField(max_length=32)
 usergroup_user = models.ManyToManyField('UserGroup')

Django model会自动创建第3张关系表,用于对应user id 和usergroup id

这是UserGroup表

Django-Model数据库操作(增删改查、连表结构)详解

这是User表

Django-Model数据库操作(增删改查、连表结构)详解

这是Django自动生成的对应关系表

Django-Model数据库操作(增删改查、连表结构)详解

user_id = 1 为 yangmv,同时属于1,2(技术部,运营部)

一对一: (一对多增加了不能重复)

class User2(models.Model):
 name = models.CharField(max_length=16)
 sex = models.CharField(max_length=16)
 email = models.EmailField(max_length=32)
 
class Admin(models.Model):
 username = models.CharField(max_length=32)
 password = models.CharField(max_length=32)
 admin_user2 = models.OneToOneField('User2')

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

连接Mysql

DATABASES ={
'default':{
'ENGINE':'django.db.backends.mysql',
'NAME':'dbname',
'USER':'root',
'PASSWORD':'xxx',
'HOST':'',
'PORT':'',
}
}

一对多操作实例

首先生成2个表

from django.db import models
 
class Group2(models.Model):
 caption = models.CharField(max_length=32)
 
class User2(models.Model):
 username = models.CharField(max_length=32)
 group2 = models.ForeignKey('Group2')

Django-Model数据库操作(增删改查、连表结构)详解

input和select标签用forms生成

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

先执行create_group生成3个group

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

已经查询出Group数据

添加

方法1,方法2

def create_user(request):
 obj = Forign.UserForm(request.POST)
 if request.method == 'POST':
 if obj.is_valid():
  all_data = obj.clean()
  #print all_data
  #获取提交页面提交来的数据{'username': u'yang1', 'usergroup': 1}
  #方法1,先获取对象,添加
  #group_obj = models.Group2.objects.get(id=all_data['usergroup'])
  #models.User2.objects.create(username=all_data['username'],usergroup=group_obj)
  #方法2(推荐)
  models.User2.objects.create(username=all_data['username'],group2_id=all_data['usergroup'])
  #django会自动把数据库group2变为group2_id
 else:
  error = obj.errors
  print error['username'][0]
  print error['usergroup'][0]
 return render(request,'forign/create_user.html',{'obj':obj})

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

方法3

Django-Model数据库操作(增删改查、连表结构)详解

Django-Model数据库操作(增删改查、连表结构)详解

def create_user(request):
 obj = Forign.UserForm(request.POST)
 if request.method == 'POST':
 if obj.is_valid():
  all_data = obj.clean()
  #print all_data
  #获取提交页面提交来的数据{'username': u'yang1', 'usergroup': 1}
  #方法1,先获取对象,添加
  #group_obj = models.Group2.objects.get(id=all_data['usergroup'])
  #models.User2.objects.create(username=all_data['username'],usergroup=group_obj)
  #方法2(推荐)
  #models.User2.objects.create(username=all_data['username'],group2_id=all_data['usergroup'])
  #django会自动把数据库group2变为group2_id
  #方法3(推荐)
  models.User2.objects.create(**all_data)
  print models.User2.objects.all().count()
 else:
  pass
  # error = obj.errors
  # print error['username'][0]
  # print error['usergroup_id'][0]
 return render(request,'forign/create_user.html',{'obj':obj})

Django-Model数据库操作(增删改查、连表结构)详解 

Django-Model数据库操作(增删改查、连表结构)详解 

查询。展示出所有的数据

def create_user(request):
 obj = Forign.UserForm(request.POST)
 if request.method == 'POST':
 if obj.is_valid():
  all_data = obj.clean()
  #方法3(推荐)
  models.User2.objects.create(**all_data)
  print models.User2.objects.all().count()
 else:
  pass
 user_list = models.User2.objects.all()
 return render(request,'forign/create_user.html',{'obj':obj,'user_list':user_list})
<table border="1">
 {% for item in user_list %}
 <tr>
  <td>{{ item.username }}</td>
  <td>{{ item.group2.caption }}</td>
 </tr>
 {% endfor %}
</table>

Django-Model数据库操作(增删改查、连表结构)详解

GET方式查询

def create_user(request):
 obj = Forign.UserForm(request.POST)
 if request.method == 'POST':
 if obj.is_valid():
  all_data = obj.clean()
  #方法3(推荐)
  models.User2.objects.create(**all_data)
  print models.User2.objects.all().count()
 else:
  pass
 #查用户
 get_user = request.GET.get('username')
 user_list = models.User2.objects.filter(username=get_user)
 return render(request,'forign/create_user.html',{'obj':obj,'user_list':user_list})

Django-Model数据库操作(增删改查、连表结构)详解

#查组
get_val = request.GET.get('group')
user_list = models.User2.objects.filter(group2__caption=get_val)

Django-Model数据库操作(增删改查、连表结构)详解

一对多跨表操作,总结

1、group2对应的是一个对象

2、创建数据 group2_id ,直接查询数据库

3、获取数据,通过. group2.caption

4、查询数据,通过__ group2__caption

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中让MySQL查询结果返回字典类型的方法
Aug 22 Python
Python自动重试HTTP连接装饰器
Apr 28 Python
Python中map和列表推导效率比较实例分析
Jun 17 Python
解决Python3 抓取微信账单信息问题
Jul 19 Python
Django 外键的使用方法详解
Jul 19 Python
Python如何使用argparse模块处理命令行参数
Dec 11 Python
Python字典底层实现原理详解
Dec 18 Python
Python编程快速上手——PDF文件操作案例分析
Feb 28 Python
利用Python如何实时检测自身内存占用
May 09 Python
Python matplotlib 绘制双Y轴曲线图的示例代码
Jun 12 Python
Python join()函数原理及使用方法
Nov 14 Python
Python结合百度语音识别实现实时翻译软件的实现
Jan 18 Python
python通过TimedRotatingFileHandler按时间切割日志
Jul 17 #Python
python递归法实现简易连连看小游戏
Mar 25 #Python
django2笔记之路由path语法的实现
Jul 17 #Python
Django之创建引擎索引报错及解决详解
Jul 17 #Python
python实现连连看辅助之图像识别延伸
Jul 17 #Python
Django 路由控制的实现
Jul 17 #Python
详解python实现数据归一化处理的方式:(0,1)标准化
Jul 17 #Python
You might like
Zend的Registry机制的使用说明
2013/05/02 PHP
php比较两个绝对时间的大小
2014/01/31 PHP
PHP程序员的技术成长规划
2016/03/25 PHP
Laravel框架查询构造器 CURD操作示例
2019/09/04 PHP
JavaScript高级程序设计 阅读笔记(十二) js内置对象Math
2012/08/14 Javascript
jQuery中:has选择器用法实例
2014/12/30 Javascript
深入理解JavaScript中的箭头函数
2015/07/28 Javascript
基于Javascript实现二级联动菜单效果
2016/03/04 Javascript
jQuery Mobile页面返回不需要重新get
2016/04/26 Javascript
JS获取复选框的值,并传递到后台的实现方法
2016/05/30 Javascript
jQuery简单设置文本框回车事件的方法
2016/08/01 Javascript
基于JavaScript实现熔岩灯效果导航菜单
2017/01/04 Javascript
神级程序员JavaScript300行代码搞定汉字转拼音
2017/05/20 Javascript
BACKBONE.JS 简单入门范例
2017/10/17 Javascript
如何在基于vue-cli的项目自定义打包环境
2018/11/10 Javascript
微信小程序云开发获取文件夹下所有文件(推荐)
2019/11/14 Javascript
浅谈nuxtjs校验登录中间件和混入(mixin)
2020/11/06 Javascript
vue实现标签云效果的示例
2020/11/09 Javascript
JavaScript 声明私有变量的两种方式
2021/02/05 Javascript
[02:41]DOTA2英雄基础教程 谜团
2013/12/10 DOTA
[06:43]2018DOTA2国际邀请赛寻真——VGJ.Thunder
2018/08/11 DOTA
Python实现删除文件但保留指定文件
2015/06/21 Python
Django框架使用富文本编辑器Uedit的方法分析
2018/07/31 Python
搞清楚 Python traceback的具体使用方法
2019/05/13 Python
python实现多进程通信实例分析
2019/09/01 Python
python同义词替换的实现(jieba分词)
2020/01/21 Python
Python使用qrcode二维码库生成二维码方法详解
2020/02/17 Python
Python 批量读取文件中指定字符的实现
2020/03/06 Python
django之导入并执行自定义的函数模块图解
2020/04/01 Python
Python Selenium异常处理的实例分析
2021/02/28 Python
英国珠宝钟表和家居礼品精品店:David Shuttle
2018/02/24 全球购物
PHP两种查询函数array/row的区别
2013/06/03 面试题
大学生新学期计划书
2014/04/28 职场文书
建筑投标担保书
2014/05/20 职场文书
Win11更新失败并提示0xc1900101
2022/04/19 数码科技
Python matplotlib 利用随机函数生成变化图形
2022/04/26 Python