【基本数据访问】

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】【三】模型的更多相关文章

  1. Django中模型(三)

    Django中模型(三) 四.模型成员 1.类属性 objects:是Manager类的一个对象,作用是与数据库进行交互. 定义模型类时,没有定义管理器,则默认创建名为objects的管理器. 2.自 ...

  2. 64、django之模型层(model)--建表、查询、删除基础

    要说一个项目最重要的部分是什么那铁定数据了,也就是数据库,这篇就开始带大家走进django关于模型层model的使用,model主要就是操纵数据库不使用sql语句的情况下完成数据库的增删改查.本篇仅带 ...

  3. 初识DJango——MTV模型

    一.Django—MTV模型 Django的MTV分别代表: Model(模型):负责业务对象与数据库的对象(ORM) Template(模版):负责如何把页面展示给用户 View(视图):负责业务逻 ...

  4. 【Django】模型层说明

    [Django模型层] 之前大概介绍Django的文章居然写了两篇..这篇是重点关注了Django的模型层来进行学习. ■ 模型定义 众所周知,Django中的模型定义就是定义一个类,其基本结构是这样 ...

  5. Django笔记--模型

    ORM是"对象-关系-映射"的简称,在Django当中,ORM就是模型类的管理器对象.操作顺序是先定义模型类,再定义模型类管理器,然后在模型类中实例化一个模型类管理器的对象,作为模 ...

  6. django之模型层(model)--建表、查询、删除基础

    要说一个项目最重要的部分是什么那铁定数据了,也就是数据库,这篇就开始带大家走进django关于模型层model的使用,model主要就是操纵数据库不使用sql语句的情况下完成数据库的增删改查.本篇仅带 ...

  7. python 全栈开发,Day70(模板自定义标签和过滤器,模板继承 (extend),Django的模型层-ORM简介)

    昨日内容回顾 视图函数: request对象 request.path 请求路径 request.GET GET请求数据 QueryDict {} request.POST POST请求数据 Quer ...

  8. django ORM模型表的一对多、多对多关系、万能双下划线查询

    一.外键使用 在 MySQL 中,如果使用InnoDB引擎,则支持外键约束.(另一种常用的MyIsam引擎不支持外键) 定义外键的语法为fieldname=models.ForeignKey(to_c ...

  9. [Django学习]模型

    ORM简介 MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库 ORM是“对象-关系-映射”的简称 ...

  10. django之模型

    ORM简介 MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库 ORM是“对象-关系-映射”的简称 ...

随机推荐

  1. navicat链接阿里云mysql报80070007: SSH Tunnel: Server does not support diffie-hellman-group1-sha1 for keyexchange

      http://www.jianshu.com/p/200572ed066c navicat 链接数据库 使用navicat 的ssh通道连接数据库回遇到权限问题 错误代码如下: 80070007: ...

  2. Jmeter压力测试和接口测试

    jmeter是apache公司基于java开发的一款开源压力测试工具,体积小,功能全,使用方便,是一个比较轻量级的测试工具,使用起来非常简单.因为jmeter是java开发的,所以运行的时候必须先要安 ...

  3. 直播协议的选择:RTMP vs. HLS

    文章转自:直播协议的选择:RTMP vs. HLS 前言 随着直播业务的兴起,越来越多的直播平台开始涌现,这火热的程度好像一个应用不带上直播业务出来都不好意思跟人打招呼.想要做一个直播业务,主要包括三 ...

  4. Python框架----cookie和session

    一.cookie和session的介绍 cookie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又需要“保持状态”,因此cookie就是在这样一个场景下诞生. cookie ...

  5. django框架基本介绍

    一.mvc和mtv 1.mvc介绍 MVC,全名是Model View Controller,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控制器( ...

  6. Tomcat启动报错:[Failed to start component]的解决方案

    在MyEclipse中启动Tomcat,该Tomcat仅部署了一个报错项目,启动Tomcat Server的全部信息如下: usage: java org.apache.catalina.startu ...

  7. Tencent QQ现在就是一个十八层地狱下面的大恶魔-删除右键里的"通过QQ发送到"

    都是流氓软件, 有人推荐装什么管家什么助手来清除, 那就是请走一个流氓又引进另外一个流氓. 下面的注册表项直接手工删除 32位系统: windows Registry Editor Version 5 ...

  8. django crontab 定时任务

    分 时 日 月 周 命令(最好用绝对路径)比如: * * * * * rm -fr /mnt/* //每分钟执行一次对/mnt目录下文件的删除*/2 * * * * rm -fr /mnt/* //每 ...

  9. jquery的$post方法不发送空数组的解决办法

    问题:jquery里的ajax在提交post请求时,如果数据里有一个空数组,则这个空数组不会提交上去 技术上的解决办法如下: 源代码: var params = { type : , ids:[] } ...

  10. P2048 [NOI2010]超级钢琴(RMQ+堆+贪心)

    P2048 [NOI2010]超级钢琴 区间和--->前缀和做差 多次查询区间和最大--->前缀和RMQ 每次取出最大的区间和--->堆 于是我们设个3元组$(o,l,r)$,表示左 ...