一、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模型基础第一节的更多相关文章

  1. 六、Django模型基础第一节

    1 数据库的连接配置 django 连接mysql的配置流程: 安装 pymysql pip install pymysql 创建数据库用户 '; grant all on *.* to 'xiang ...

  2. Django学习系列之Form基础

     Django学习系列之Form基础 2015-05-15 07:14:57 标签:form django 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追 ...

  3. Django学习之django自带的contentType表 GenericRelation GenericForeignKey

    Django学习之django自带的contentType表   通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...

  4. day 94 Django学习之django自带的contentType表

    Django学习之django自带的contentType表   通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...

  5. day 93 Django学习之django自带的contentType表

    Django学习之django自带的contentType表   通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/a ...

  6. Django学习之django自带的contentType表

    Django学习之django自带的contentType表 通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net/aar ...

  7. day 91 Django学习之django自带的contentType表

      Django学习之django自带的contentType表   通过django的contentType表来搞定一个表里面有多个外键的简单处理: 摘自:https://blog.csdn.net ...

  8. Django学习---Web框架及基础知识

    Django学习---Web框架 web框架的本质 我们在学socket,我们创建一个socketserver,然后运行起来,有一个client客户端要连接socket服务端,连接上之后,如果两边都没 ...

  9. django学习-10.django连接mysql数据库和创建数据表

    1.django模型 Django对各种数据库提供了很好的支持,包括:PostgreSQL.MySQL.SQLite.Oracle. Django为这些数据库提供了统一的调用API. 我们可以根据自己 ...

随机推荐

  1. Confluence 6 重新获得附件指南

    每一个文件在恢复上传到 Confluence 的时候必须单独重命名,你可以通过下面说明的 3 个方法中选择一个进行操作: 选择 A - 通过文件名恢复附件 如果你知道你需要恢复的每一个文件名,尤其是你 ...

  2. Confluence 6 在编辑器中控制参数的显示

    你可以决定宏参数在 Confluence 编辑器中如何进行显示的. 在默认的情况下,在宏占位符下尽可能显示能显示的所有参数: 你可以控制这里显示的参数数量,通过这种控制你可能尽量的为编辑者提供有效的信 ...

  3. java读取pdf和MS Office文档

    有时候PDF中的文字无法复制,这可能是因为PDF文件加密了,不过使用PDFBox开源软件就可以把它读出来. 还有一个用于创建PDF文件的项目----iText. PDFBox下面有两个子项目:Font ...

  4. rpm 命令使用 和 lsof -p 1406 使用

    #安装RPM -v 显示详细信息 -h 显示进度 -i 安装 -U 升级 -q 查询 -ql 查看rpm 包装的文件 - qf 查看命令属于哪个RPM 包 -qi 查看RPM包的详细信息 [root@ ...

  5. 函数sigsuspend

    sigqueue函数原型: 函数作用:新的发送信号系统调用,主要是针对实时信号提出的支持信号带有参数,与函数sigaction()配合使用 int sigqueue(pid_t pid, int si ...

  6. mysql如何添加一个表的外键

    1:创建一个父表,主键作为子表的外键: create table province( pId int primary key auto_increment, pName varchar() ); 2: ...

  7. Java 集合Collection与List的详解

    1.什么是集合 存储对象的容器,面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,存储对象,集合是存储对象最常用的一种方式. 集合的出现就是为了持有对象.集合中可以存储任意类型的 ...

  8. csv导入数据到mongodb3.2

    mongoimport.exe -d paper -c paper K:\paper.csv --type csv -f id,name 数据库名 表名      文件所在位置      文件类型   ...

  9. jQuery插件学习之选项卡Tab

    在网站开发中经常会用到选项卡功能,为了节省一下写代码时间,封装了一下tab插件,方便调用. 来看一下效果: tab-1 tab-2 tab-3 tabs-1-panel tabs-2-panel ta ...

  10. C# 之设计原则

    代码也需要有秩序,就像世界需要秩序,基于SOLID architecture principles. 一.SOLID原则 S.O.L.I.D.是一组面对面向对象设计的最佳实践的设计原则.术语来自Rob ...