Django 学习第六天——Django模型基础第一节
一、Django 的 ORM 简介:
Django的ORM系统的分析:

1、ORM 概念:对象关系映射(Object Relational Mapping,简称ORM)
2、ORM的优势:不用直接编写SQL代码,只需像操作对象一样从数据库操作数据;
django 模型映射关系:

1、模型类必须写在 app 下的 models.py 文件里;
2、模型如果需要映射到数据库,所在的 app 必须被注册(在主目录的 settings.py 文件中的 INSTALLED_APPS 中添加该 app 名);
3、一个数据表对应一个模型类,表中的字段,对应模型中的类属性;
二、数据库连接配置:
数据库配置:
在主目录的 settings.py 中配置 DATABASES:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 数据库引擎
'NAME': 'mydb', #数据库名称
'USER': 'user', # 链接数据库的用户名
'PASSWORD': 'password', # 链接数据库的密码
'HOST': '127.0.0.1', # mysql服务器的域名ip地址
'PORT': '', # mysql的一个端口号,默认是3306
}
}
设置时区:再主目录中的 settings.py 中设置 TIME_ZONE = 'Asia/ShangHai' # 北京时间
创建一个管理员用户taka账号,密码为 taka:
CREATE USER 'taka'@'%'IDENTIFIED BY 'taka';
给这个用户授予所有远程访问,这个用户主要用于管理整个数据库,备份,还原等操作。
GRANT ALL ON *.* TO 'taka'@'%';
使授权立即生效:
FLUSH PRIVILEGES;
pymysql 数据库链接器的配置:
安装:pip install pymysql
在主目录下的 __init__.py 文件添加:
import pymysql pymysql.install_as_MySQLdb()
三、模型的创建与映射:
使用 django 中的模型:
每一个模型都是django.db.models.Model 的子类
在 app 下面的 models.py 中创建 django 的模型类:

注:这个 __str__ 方法的作用是我们在查询是看到的东西
常用的模型字段:
IntegerField : 整型,映射到数据库中的int类型。
SmallIntegerField : 小整形
CharField: 字符类型,映射到数据库中的varchar类型,必须通过max_length指定最大长度。
TextField: 文本类型,映射到数据库中的text类型。
BooleanField: 布尔类型,映射到数据库中的tinyint类型,在使用的时候,传递
True/False进去。如果要可以为空,则用NullBooleanField。
DateField: 日期类型,没有时间。映射到数据库中是date类型,在使用的时候,可
以设置- - DateField.auto_now每次保存对象时,自动设置该字段为当前时间。设置
DateField.auto_now_add当对象第一次被创建时自动设置当前时间。
DateTimeField: 日期时间类型。映射到数据库中的是datetime类型,在使用的时候,传
递datetime.datetime()进去
字段常用的参数:
primary_key: 指定是否为主键。
auto_increment:自增长
unique: 指定是否唯一。
null: 指定是否为空,默认为False。
blank: 等于True时form表单验证时可以为空,默认为False。
default: 设置默认值。
verbose_name:备注;也可以直接写在第一位不用加参数
DateTimeField(DateField)—— auto_now=True:
每次修改都会将当前时间更新进去,只有调用,QuerySet.update方法将不会调用。这个参数只是Date和DateTime以及TimModel.save()方法才会调用e类才有的。
DateTimeField(DateField)—— auto_now_add=True:
第一次添加进去,都会将当前时间设置进去。以后修改,不会修改这个值。
将模型类映射到数据库:
在执行命令前,保证创建模型的 app 是已经注册过的 app;
1、首先执行以下命令,会创建映射文件:
python manage.py makemigrations
该命令后面可以跟 app 名称,表示指定对某个 app 的模型进行映射,没写所有的 app 都执行。
python manage.py sqlmigrate app_name 0001 # app_name时app的名字,0001 是映射文件的前缀
执行该命令可以看到执行的 sql 原生语句
2、再执行以下命令,将映射文件中的映射数据提交到数据库中
python manage.py migrate
该命令后面可以跟 app 名称,表示指定对某个 app 的模型进行迁移,没写所有的 app 都执行。
将模型类映射到数据库:
打开数据我们能看到创建的以 app 名 _模型名的数据表,而其他的一些表格是 django 自动生成的;
注意:如果要删除表,那么可以去 django 模型中注释掉模型类,然后执行映射的命令,不要手动再命令行里面去删除;
四、数据的 增-删-改-查:
调试工具:在根目录执行:
先安装ipython:pip install ipython
python manage.py shell
再视图函数中导入 创建的 模型类,然后使用下面的方法实现增,删,改,查操作数据;
增:

查:

注:通过print可以在后台看到我们访问到的数据,并且输出方式就是模型中的__str__的格式.
all() 和 filter() 方法返回的是 QuerySet 对象;
get() 方式返回的单个对象,如果符合条件的对象有多个,则 get 报错!
改:

删:

Django 学习第六天——Django模型基础第一节的更多相关文章
- 六、Django模型基础第一节
1 数据库的连接配置 django 连接mysql的配置流程: 安装 pymysql pip install pymysql 创建数据库用户 '; grant all on *.* to 'xiang ...
- Django学习系列之Form基础
Django学习系列之Form基础 2015-05-15 07:14:57 标签:form django 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追 ...
- Django学习之django自带的contentType表 GenericRelation GenericForeignKey
Django学习之django自带的contentType表 通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...
- day 94 Django学习之django自带的contentType表
Django学习之django自带的contentType表 通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...
- day 93 Django学习之django自带的contentType表
Django学习之django自带的contentType表 通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...
- Django学习之django自带的contentType表
Django学习之django自带的contentType表 通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/aar ...
- day 91 Django学习之django自带的contentType表
Django学习之django自带的contentType表 通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net ...
- Django学习---Web框架及基础知识
Django学习---Web框架 web框架的本质 我们在学socket,我们创建一个socketserver,然后运行起来,有一个client客户端要连接socket服务端,连接上之后,如果两边都没 ...
- django学习-10.django连接mysql数据库和创建数据表
1.django模型 Django对各种数据库提供了很好的支持,包括:PostgreSQL.MySQL.SQLite.Oracle. Django为这些数据库提供了统一的调用API. 我们可以根据自己 ...
随机推荐
- Confluence 6 已经存在的安装配置数据库字符集编码
针对已经存在的 Confluence 安装,如果你安装的 Confluence 版本是 6.4 或者早期的版本,我们在安装的时候没有检查你数据库的字符设置. 如果你的数据库当前没有被配置使用 UTF- ...
- ionic3 极光推送
参考网站:http://www.jianshu.com/p/eb8ab29329d9 遇到的问题是 执行以下命令一直报错 cordova plugin add https://github.com/ ...
- matlab 测试 数字二次混频
% test2 clear; clf; close all Fs=800000;%采样频率800k fz=80000;%载波频率80k fz1=3000;%载波频率3k fj=79000;%基波频率7 ...
- swoole 使用异步redis的前置条件
redis安装 官网下载redis 下载完成之后解压: 进入redis目录执行make: 进入src目录启动redis 启动成功如下: 启动后连接redis 编译安装hiredis 下载:https: ...
- bzoj 1951
这道题告诉了我们一个很重要的道理:看到题,先想明白再动手! 题意:求对999911659取模的值 首先,由于n的数据范围不是很大(至少不是很大),所以可以O()枚举所有约数分别求组合数 但是有个问题: ...
- C++ LocalAlloc() & LocalSize() & LocalFree ()
关于LocalAlloc function,参考:https://msdn.microsoft.com/en-us/library/windows/desktop/aa366723(v=vs.85). ...
- c++实现 给定直角停车位两个点,求取剩余两点坐标。
//2018-09-08-fourmi /*************************include head files************************************ ...
- jenkins卡在等待界面解决方法
1.安装jenkins最新版的时候,发现一直卡在等待界面上 如图显示: 原因:jenkins里面文件指向国外的官网,因为防火墙的原因连不上 解决方法:将配置文件里面的url换成国内的即可
- KnockoutJs学习笔记(五)
作为一名初学者来说,一篇篇的按顺序看官网上的文档的确是一件很痛苦的事情,毕竟它的排列也并非是由浅及深的排列,其中的顺序也颇耐人寻味,于是这篇文章我又跳过了Reference部分,进而进入到具体的bin ...
- 删除Apache服务的命令
转到\Apache24\bin目录下,使用cmd命令sc delete apache2.2