Django框架的使用教程--mysql数据库[三]
Django的数据库
1.在Django_test下的view.py里面model定义模型
from django.db import models # Create your models here. # 定义游戏模型类,继承models.Model
class GameInfo(models.Model):
gtitle = models.CharField(max_length=20, verbose_name='名称')
game_date = models.DateField(verbose_name='游戏发布日期')
# default可以设置默认值
game_download = models.IntegerField(default=0, verbose_name='游戏下载量')
gcommnet = models.IntegerField(default=0, verbose_name='游戏评论量')
is_delete = models.BooleanField(default=False, verbose_name="逻辑删除") # 定义元数据
class Meta:
# db_tablespace 指定这个模型对应的数据表放在哪个数据空间
# app_label 指定模型类的应用app
db_table = 'game' # 指名数据库类
verbose_name = '游戏' # 在admin站点显示的名称
verbose_name_plural = verbose_name # 显示复数名称 def __str__(self):
"""定义数据对象的显示信息"""
return self.gtitle # 定义游戏人物类
# 定义英雄模型类HeroInfo
class HeroInfo(models.Model):
GENDER_CHOICES = (
(0, 'male'),
(1, 'female')
)
hname = models.CharField(max_length=20, verbose_name='名称')
hgender = models.SmallIntegerField(choices=GENDER_CHOICES, default=0, verbose_name='性别')
hcomment = models.CharField(max_length=200, null=True, verbose_name='描述信息')
# 关联数据表 外键
hgame = models.ForeignKey(GameInfo, on_delete=models.CASCADE, verbose_name='游戏') # 外键
is_delete = models.BooleanField(default=False, verbose_name='逻辑删除') class Meta:
db_table = 'game_heros'
verbose_name = '英雄'
verbose_name_plural = verbose_name def __str__(self):
return self.hname
2.生成迁移文件

3.数据库迁移

4.数据库插入数据(插入game表的数据)
insert into game(gtitle,game_date, game_download,gcommnet,is_delete) values
('王者荣耀','2015-5-1',122,343,0),
('绝地求生','2016-7-24',363,403,0),
('天天酷跑','2005-12-24',20,80,0),
('时空猎人','1999-11-11',58,24,0);
插入game_heros数据表的数据
insert into game_heros(hname,hgender,hgame_id,hcomment,is_delete) values
('妲己',1,1,'魅惑',0),
('凯',0,1,'变身拿刀',0),
('诸葛亮',1,1,'远程导弹',0),
('黄总',1,1,'防御塔',0),
('吃鸡1号',0,1,'吃鸡1号技能',0),
('吃鸡2号',1,2,'吃鸡1号技能',0),
('吃鸡3号',1,2,'吃鸡1号技能',0),
('吃鸡4号',1,2,'吃鸡1号技能',0),
('吃鸡5号',0,2,'吃鸡5号技能',0),
('天天1号',1,3,'天天1号技能',0),
('天天2号',0,3,'天天2号技能',0),
('天天3号',1,3,'天天3号技能',0),
('天天4号',0,3,'天天4号技能',0),
('时空1号',1,4,'时空1号技能',0),
('时空2号',0,4,'时空2号技能',0),
('时空3号',0,4,'时空3号技能',0),
('时空4号',0,4,'时空4号技能',0);
数据库的操作
安装ipython
pip install ipython
进入命令脚本
python manage.py shell
数据库的增加
create方法
模型类.objects.create(数据表参数)
save方法
变量 = 模型类(参数)
变量.save()
数据库的查询
查询多个值
模型类.objects.all()
查询单个值
模型类.objects.get(id=2)
查询结果的数量
模型类.objects.count()
过滤查询
模型类.objects.filter(id__exact=1)
模糊查询
模型类.objects.filter(gtitle__contains='王')
模型类.objects.filter(gtitle__endswith='耀')
模型类.objects.filter(gtitle__startswith='天')
空查询
模型类.objects.filter(gtitle__isnull=False)
范围查询
模型类.objects.filter(id__in=[1,2])
比较查询
gt :大于
gte: 大于等于
lt :小与
lte: 小与等于
模型类.objects.filter(id__gt=3)
不等于
模型类.objects.exclude(id=1)
日期查询
模型类.objects.filter(game_date__gt=date(1900,1,1))
F对象(根据属性对比值)
from django.db.models import F
模型类.objects.filter(game_download__gte=F('gcomment'))
Q对象
与:
模型类.objects.filter(game_download__gt=20,id__lt=3)
或:
模型类.object.filter(game_download__gt=20).filter(id_lt=3)
用Q来表示&和|的连接:
模型类.objects.filter(Q(game_download__gt=20) | Q(pk__lt=3))
聚合函数
Avg 平均,Count 数量,Max 最大,Min 最小,Sum 求和:
from jango.db.models import Sum
模型类.objects.aggregate(Sum(game_download))
排序(默认升序,加-为降序)
模型类.objects.all().order_by('game_download')
模型类.objects.all().order_by('-bread')
关联查询
一对多:
g = GameInfo.objects.get(id=1)
g.heroinfo_set.all()
多对一:
h = HeroInfo.objects.get(id=1)
h.hgame
多对一:
h = HeroInfo.objects.get(id=1)
h.hgame_id
关联过滤查询:
模型类.objects.filter(heroinfo__hname='妲己')
模型类.objects.filter(hgame__btitle='王者荣耀')
数据库的修改
save方法
hero = HeroInfo.objects.get(hname='妲己')
hero.hname = '王昭君'
hero.save()
update方法
HeroInfo.objects.filter(hname='妲己').update(hname='王昭君')
数据库的删除
delete方法
hero = HeroInfo.objects.get(id=3)
hero.delete()
模型类.objects.filter().delete()
HeroInfo.objects.filter(id=4).delete()
查询集的两大特性
查询集,也称查询结果集、QuerySet,表示从数据库中获取的对象集合。
1.惰性:创建查询集不会访问数据库,直到调用数据时,才会访问数据库,调用数据的情况包括迭代、序列化、与if合用
2.缓存:使用同一个查询集,第一次使用时会发生数据库的查询,然后Django会把结果缓存下来,再次使用这个查询集时会使用缓存的数据,减少了数据库的查询次数。
自定义管理器
修改原始管理器的方法
# 在django_test下的models.py文件中定义类 class GameInfoManager(models.Manager):
def all(self):
return super().filter(is_delete=False) # 在模型类GameInfo中定义管理器
class GameInfo(models.Model):
games = GamesInfoManager() #使用方法
GameInfo.games.all()
在自定义的管理类可以自定义新的方法
Django框架的使用教程--mysql数据库[三]的更多相关文章
- 第三百零六节,Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置
Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...
- 第三百零九节,Django框架,models.py模块,数据库操作——F和Q()运算符:|或者、&并且——queryset对象序列化
第三百零九节,Django框架,models.py模块,数据库操作——F()和Q()运算符:|或者.&并且 F()可以将数据库里的数字类型的数据,转换为可以数字类型 首先要导入 from dj ...
- 第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多、一对一、多对多
第三百零八节,Django框架,models.py模块,数据库操作——链表结构,一对多.一对一.多对多 链表操作 链表,就是一张表的外键字段,连接另外一张表的主键字段 一对多 models.Forei ...
- 第三百零七节,Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- Python中的Django框架中prefetch_related()函数对数据库查询的优化
实例的背景说明 假定一个个人信息系统,需要记录系统中各个人的故乡.居住地.以及到过的城市.数据库设计如下: Models.py 内容如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 1 ...
- 四 Django框架,models.py模块,数据库操作——创建表、数据类型、索引、admin后台,补充Django目录说明以及全局配置文件配置
Django框架,models.py模块,数据库操作——创建表.数据类型.索引.admin后台,补充Django目录说明以及全局配置文件配置 数据库配置 django默认支持sqlite,mysql, ...
- Web框架之Django-20-基于mysql数据库的连接
Web框架之Django-20-基于mysql数据库的连接 想要连接mysql首先需要安装pymysql这个驱动 然后在app的init文件中引入驱动 import pymysql pym ...
- 五 Django框架,models.py模块,数据库操作——表类容的增删改查
Django框架,models.py模块,数据库操作——表类容的增删改查 增加数据 create()方法,增加数据 save()方法,写入数据 第一种方式 表类名称(字段=值) 需要save()方法, ...
- Django中的app及mysql数据库篇(ORM操作)
Django常见命令 在Django的使用过程中需要使用命令让Django进行一些操作,例如创建Django项目.启动Django程序.创建新的APP.数据库迁移等. 创建Django项目 一把我们都 ...
随机推荐
- Android生成二维码--保存和分享二维码图片
之前写过生成自定义二维码的两篇文章:<Android生成自定义二维码><Android生成二维码–拍照或从相册选取图片>,下面就介绍一下Android应用内如何保存以及分享二维 ...
- salesforce lightning零基础学习(五) 事件阶段(component events phase)
上一篇介绍了lightning component events的简单介绍.此篇针对上一篇进行深入,主要讲的内容为component event中的阶段(Phase). 一. 阶段(Phase)的概念 ...
- 从零开始学 Web 之 Ajax(四)接口文档,验证用户名唯一性案例
大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...
- Feign快速入门
一.Feign简介1.Feign是一个声明式的web服务客户端,使用Feign编写web服务客户端更加容易2.具有可插拔注解支持,包括Feign注解和JAX-RS注解,还支持可插拔的编码器与解码器3. ...
- 从完整备份恢复单个innodb表
现在大多数同学在线上采取的备份策略都是xtrabackup全备+binlog备份,那么当某天某张表意外的删除那么如何从xtrabackup全备中恢复呢?从mysql 5.6版本开始,支持可移动表空间( ...
- linux搭建sftp服务器
转自:http://blog.csdn.net/superswordsman/article/details/49331539 最近工作需要用到sftp服务器,被网上各种方法尤其是权限设置问题搞得晕头 ...
- JS判断是否是数组的四种做法
一.前言 如何判断一个对象或一个值是否是一个数组,在面试或工作中我们常常会遇到这个问题,既然出现频率高,想着还是做个整理,那么本文主要基于几种判断方式,以及方式判断的原理,是否存在问题展开讨论. 二. ...
- Oracle添加定时任务
1.创建存储过程 注:执行语句后,如果需要请添加commit 2.添加定时job,执行存储过程 declare job_delete number; begin dbms_job.submit( jo ...
- 光流法详解之二(HS光流)
Horn–Schunck光流算法[1]是一种全局方法估算光流场. 参考博文:https://blog.csdn.net/hhyh612/article/details/79216021 假设条件: H ...
- [转]Angular2 Material2 封装组件 —— confirmDialog确定框
本文转自:https://www.jianshu.com/p/0c566fc1730d 环境: Angular 4.0.0 Angular2 Material2 2.0.0-beta.3 node v ...