【Django】【三】模型
【基本数据访问】
1. models.py写模型
2. 数据库迁移
guest> python manage.py makemigrations sign
guest> python manage.py migrate
3. admin.py + admin后台操作
4. 基本数据访问
guest> python manage.py shell
(1)进入>>>模式
>>> from sign.models import Event,Guest
>>> Event.objects.all()
<QuerySet [<Event:小米5发布会>]>
>>> Guest.objects.all()
<QuerySet [<Guest:jack>]>
(2)插入数据:
>>> from datetime import datetime
>>> from sign.models import Event
>>> from sign.models import Guest
>>> Event.objects.create(id=3,name='红米MAX发布会',limit=2000,status=True,address='北京会展中心',start_time=datetime(2017,9,27,17,0,0))
<Event:红米MAX发布会>
>>> Guest.objects.create(realname='andy',phone=13610111001,email='andy@mail.com',sign=False,event_id=3)
<Guest:andy>
>>> e1 = Event.objects.get(name='红米MAX发布会')
>>> e1
<Event:红米MAX发布会>
>>> e1.address
'北京会展中心'
>>> e1.start_time
datetime.datetime(2017,9,27,17,0,0)
>>> Event.objects.get(name='红米MAX发布会').status
True
>>> Event.objects.get(name='啊轻松扫').address
sign.models.DoesNotExist: Event matching query does not exist.
过滤
>>> e2 = Event.objects.filter(name__contains='发布会')
>>> e2
<QuerySet [<Event:小米5发布会>,<Event:红米MAX发布会>]>
>>> g1 = Guest.objects.get(phone='13611001101')
>>> g1.event
<Event:红米MAX发布会>
>>> g1.event.address
'北京会展中心'
(3)删除数据
>>> g2 = Guest.objects.get(phone='13611001101')
>>> g2.delete()
(1,{'sign.Guest':1})
>>> Guest.objects.get(phone='13611001101').delete()
(1,{'sign.Guest':1})
(4)更新数据
方式1:
>>> g3 = Guest.objects.get(phone='13611001101')
>>> g3.realname = 'andy2'
>>> g3.save()
方式2:
>>> Guest.objects.select_for_update().filter(phone='13611001101').update(realname='andy3')
1
查看数据库,已更新
【MySQL】--由于之前用的是sqlite,所以现在要重新来过
1 数据库客户端删除数据库:
mysql> drop database 数据库名字;
【备注】如果报错:mysql errro 1010 (HY000) 参考:https://jingyan.baidu.com/article/d71306352af34613fdf475eb.html
2 清理项目中关于数据库的缓存 :删掉migrations和 __pycache__ folder
3 数据库客户端创建数据库,编码格式选择"utf-8"
mysql> CREATE DATABASE guest CHARACTER SET utf8;
4 重新执行:
python3 manage.py makemigrations app名字
python3 manage.py migrate
5. Admin 后台超级管理员账号(admin/admin123456) 也需要重新创建
cmd.exe
D:\pydj\guest>python3 manage.py createsuperuser
Username (leave blank to use 'fnngj'): admin #输入登录用户名
Email address:admin@mail.com
Password:#数据登录密码
Password(again):#再次输入密码
Superuser created successfully.
6. MySQL客户端安装
win7 我用 HeidiSQL_9.4.0.5125
【Django】【三】模型的更多相关文章
- Django中模型(三)
Django中模型(三) 四.模型成员 1.类属性 objects:是Manager类的一个对象,作用是与数据库进行交互. 定义模型类时,没有定义管理器,则默认创建名为objects的管理器. 2.自 ...
- 64、django之模型层(model)--建表、查询、删除基础
要说一个项目最重要的部分是什么那铁定数据了,也就是数据库,这篇就开始带大家走进django关于模型层model的使用,model主要就是操纵数据库不使用sql语句的情况下完成数据库的增删改查.本篇仅带 ...
- 初识DJango——MTV模型
一.Django—MTV模型 Django的MTV分别代表: Model(模型):负责业务对象与数据库的对象(ORM) Template(模版):负责如何把页面展示给用户 View(视图):负责业务逻 ...
- 【Django】模型层说明
[Django模型层] 之前大概介绍Django的文章居然写了两篇..这篇是重点关注了Django的模型层来进行学习. ■ 模型定义 众所周知,Django中的模型定义就是定义一个类,其基本结构是这样 ...
- Django笔记--模型
ORM是"对象-关系-映射"的简称,在Django当中,ORM就是模型类的管理器对象.操作顺序是先定义模型类,再定义模型类管理器,然后在模型类中实例化一个模型类管理器的对象,作为模 ...
- django之模型层(model)--建表、查询、删除基础
要说一个项目最重要的部分是什么那铁定数据了,也就是数据库,这篇就开始带大家走进django关于模型层model的使用,model主要就是操纵数据库不使用sql语句的情况下完成数据库的增删改查.本篇仅带 ...
- python 全栈开发,Day70(模板自定义标签和过滤器,模板继承 (extend),Django的模型层-ORM简介)
昨日内容回顾 视图函数: request对象 request.path 请求路径 request.GET GET请求数据 QueryDict {} request.POST POST请求数据 Quer ...
- django ORM模型表的一对多、多对多关系、万能双下划线查询
一.外键使用 在 MySQL 中,如果使用InnoDB引擎,则支持外键约束.(另一种常用的MyIsam引擎不支持外键) 定义外键的语法为fieldname=models.ForeignKey(to_c ...
- [Django学习]模型
ORM简介 MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库 ORM是“对象-关系-映射”的简称 ...
- django之模型
ORM简介 MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库 ORM是“对象-关系-映射”的简称 ...
随机推荐
- H.264流媒体协议格式中的Annex B格式和AVCC格式深度解析
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/Romantic_Energy/article/details/50508332本文需要读者对H.26 ...
- Codeforce 270A - Fancy Fence (正多边形)
Emuskald needs a fence around his farm, but he is too lazy to build it himself. So he purchased a fe ...
- mycat工作原理
Mycat的原理并不复杂,复杂的是代码,如果代码也不复杂,那么早就成为一个传说了. Mycat的原理中最重要的一个动词是“拦截”,它拦截了用户发送过来的SQL语句,首先对SQL语句做了一些特定的分析: ...
- getopt_long_only
st_i2c_parser.c中用到,遂学习一下: 参考:https://blog.csdn.net/pengrui18/article/details/8078813 https://blog.cs ...
- excel 方框打钩
将光标定位于需要打钩的地方,选择[插入]→[符号]→[其他符号] 在弹出的符号栏里,字体一定要改成[Windings2] 然后在符号栏便可以找到现成的打钩样式,点击插入,再关闭即可 提示:如果需要打叉 ...
- 01:saltstack 基本使用
1.1 准备实验环境: 安装系统 1)硬件配置如下 2) 先把光标放到”install CentOS 7”,按 Tab键编辑内核参数,添加 (net.ifnames=0 biosdevname=0) ...
- maven的使用记录
maven的使用记录 使用的版本为3.6.0. maven配置部署项目 在cmd命令行中切换到Maven项目的根目录,比如:D:/xxxwork/java/maven-test,然后执行命令:$ mv ...
- 如何用Tensorflow训练模型成pb文件和和如何加载已经训练好的模型文件
这篇薄荷主要是讲了如何用tensorflow去训练好一个模型,然后生成相应的pb文件.最后会将如何重新加载这个pb文件. 首先先放出PO主的github: https://github.com/ppp ...
- python --- 25 模块和包
一.模块 1.导入方式 自己创建的模块名称 切不可和 内置模块的一样 ① import 模块 ② import 模块 as 名 设置在此空间的名称 ③ from 模块 import ...
- 上传svn失败,代码冲突解决方式
1,修改文件后提交不了,大多是因为版本不一致造成的.更新一下,不产生冲突的情况,就可以提交了. 2,更新文件,如果出现冲突的情况,打开冲突文件test.php会看到类似以下的内容 <<&l ...