Django入门4: ORM 数据库操作

大纲

一、DjangoORM 创建基本类型及生成数据库表结构 
1、简介 
2、创建数据库 表结构 
二、Django ORM基本增删改查 
1、表数据增删改查 
2、表结构修改 
三、Django ORM 字段类型 
1、字段类型介绍 
2、字段参数介绍 
3、Django ORM 外键操作

一、DjangoORM 创建基本类型及生成数据库表结构

1、简介

ORM:关系对象映射。定义一个类自动生成数据库的表结构。

创建数据库的时候,一般有以下几种常用数据类型:数字、字符串以及时间。

ORM分为两种:

  • DB First 数据库里先创建数据库表结构,根据表结构生成类,根据类操作数据库
  • Code First 先写代码,执行代码创建数据库表结构

主流的orm都是code first。django 的orm也是code first,所以学的时候,本质就分为两块:

  • 根据类自动创建数据库表
  • 根据类对数据库表中的数据进行各种操作

2、创建数据库 表结构

  • 先写类:

app下models.py文件:

1 from django.db import models
2
3 class UserInfo(models.Model):  # 必须继承models.Model
4     # 不写则,django默认创建ID列,自增,主键
5     # 用户名列,字符串类型,指定长度
6     username = models.CharField(max_length=32)
7     password = models.CharField(max_length=64)

  • 注册APP

执行命令python manage.py makemigrations,会提示No changes detected,这是因为:执行命令时会找所有models,但是django不知道找哪个,所有需要指定一下。

settings.py:

1 INSTALLED_APPS = [
2     ‘django.contrib.admin‘,
3     ‘django.contrib.auth‘,
4     ‘django.contrib.contenttypes‘,
5     ‘django.contrib.sessions‘,
6     ‘django.contrib.messages‘,
7     ‘django.contrib.staticfiles‘,
8     ‘app01‘,            # 这里添加app
9 ]

  • 执行命令生成表结构

   1 python manage.py makemigrations # 生成migrations临时文件

    2 python manage.py migrate # 根据migrations直接生成数据库 

  执行后,从migrations便会产生操作记录。生成数据库,默认情况下用的sqlite3。可以用navicat等软件直接打开。

db.sqlite3里面包含缓存、session、cookie、静态文件以及后台管理。像咱们创建的表名叫:app01_userinfo.

  • 连接mysql数据库

如果不使用sqlite,使用mysql数据库。代码不用改、命令也不用改,只需要改下配置文件。

 1 # https://docs.djangoproject.com/en/1.10/ref/settings/#databases  官网文档
 2 # DATABASES = {             # sqlite 默认
 3 #     ‘default‘: {
 4 #         ‘ENGINE‘: ‘django.db.backends.sqlite3‘,
 5 #         ‘NAME‘: os.path.join(BASE_DIR, ‘db.sqlite3‘),
 6 #     }
 7 # }
 8 DATABASES = {               # mysql
 9     ‘default‘: {
10         ‘ENGINE‘: ‘django.db.backends.mysql‘,
11         ‘NAME‘: ‘mydatabase‘,
12         ‘USER‘: ‘mydatabaseuser‘,
13         ‘PASSWORD‘: ‘mypassword‘,
14         ‘HOST‘: ‘127.0.0.1‘,
15         ‘PORT‘: ‘3306‘,
16     }
17 }

注意:

  • 数据库名django不能创建,需要自己提前创建
  • Django默认使用MySQLdb模块链接MySQL,但python3现在还没有MySQLdb,所以改为用pymysql去连。在project项目名下的__init__.py里面
    import pymysql
    pymysql.install_as_MySQLdb()

二、Django ORM基本增删改查

1、表数据增删改查

urls.py:

  url(r‘^orm/‘,views.orm),

 1 from app01 import models  # 导入models模块
 2 def orm(request):
 3 # 创建数据
 4     # 第一种方式
 5     # models.UserInfo.objects.create(username="root",password="123")
 6     # 第二种方式
 7     # obj = models.UserInfo(username=‘fzh‘, password="iajtag")
 8     # obj.save()
 9     # 第三种方式
10     # dic = {‘username‘:‘fgf‘, ‘password‘:‘666‘}
11     # models.UserInfo.objects.create(**dic)
12
13 # 查询数据
14     # result = models.UserInfo.objects.all()  # 查询所有,为QuerySet类型,可理解成列表
15     # result = models.UserInfo.objects.filter(username="fgf",password="666")  # 列表
16     # result = models.UserInfo.objects.filter(username="fgf").first()  # 对象
17     # 条件查询。filter 相当于where查询条件,里面的","会组成and条件
18     # for row in result:  # 打印查询到数据。
19     #     print(row.id,row.username,row.password)
20
21     # 查看QuerySet类型具体做了什么事情,可以: print(result.query)
22
23 # 删除数据
24     # models.UserInfo.objects.all().delete()  # 删除所有
25     # models.UserInfo.objects.filter(id=4).delete()  # 删除所有
26
27 # 更新数据
28     # models.UserInfo.objects.all().update(password=8888)
29     # models.UserInfo.objects.filter(id=3).update(password=888888)
30
31     return HttpResponse(‘orm‘)

app01/views.py

2、表结构修改

  • 修改列

把最初定义的类中字段password = models.CharField(max_length=64)改为password = models.CharField(max_length=60)。重新执行python manage.py makemigrationspython manage.py migrate,则数据表结构更改了。如果列内内容超过定义大小,则数据就丢了。

  • 增加一列

类中增加一列,执行命令,会有提示信息,因为默认情况下是不允许为空的。这里提供两个选项。

  1. 输入一个值,新增列已存在的行默认加上输入的内容。
  2. email = models.CharField(max_length=32, null=True),允许为空

查看表结构变化时,刷新看不出来,需要重新打开表看效果。

  • 删除列

类内删掉相应的字段,执行命令即可。

三、Django ORM 字段类型

1、字段类型介绍

Django ORM 字段类型中,有CharField、EmailField、URLField、GenericIPAddressField等,实际上在数据库里都是字符串。不能做检查语法,做不了验证。那这个有什么用呢?

这些是给Django 的 admin 用的。在admin那个网页上做验证。如果不用admin,那那些都是字符串,效果都一样。

自定义自增列models.AutoField(primary_key=True)

1、models.AutoField  自增列 = int(11)
  如果没有的话,默认会生成一个名称为 id 的列,如果要显示的自定义一个自增列,必须将给列设置为主键 primary_key=True。
2、models.CharField  字符串字段
  必须 max_length 参数
3、models.BooleanField  布尔类型=tinyint(1)
  不能为空,Blank=True
4、models.ComaSeparatedIntegerField  用逗号分割的数字=varchar
  继承CharField,所以必须 max_lenght 参数
5、models.DateField  日期类型 date
  对于参数,auto_now = True 则每次更新都会更新这个时间;auto_now_add 则只是第一次创建添加,之后的更新不再改变。
6、models.DateTimeField  日期类型 datetime
  同DateField的参数
7、models.Decimal  十进制小数类型 = decimal
  必须指定整数位max_digits和小数位decimal_places
8、models.EmailField  字符串类型(正则表达式邮箱) =varchar
  对字符串进行正则表达式
9、models.FloatField  浮点类型 = double
10、models.IntegerField  整形
11、models.BigIntegerField  长整形
  integer_field_ranges = {
    ‘SmallIntegerField‘: (-32768, 32767),
    ‘IntegerField‘: (-2147483648, 2147483647),
    ‘BigIntegerField‘: (-9223372036854775808, 9223372036854775807),
    ‘PositiveSmallIntegerField‘: (0, 32767),
    ‘PositiveIntegerField‘: (0, 2147483647),
  }
12、models.IPAddressField  字符串类型(ip4正则表达式)(已弃用,用13、)
13、models.GenericIPAddressField  字符串类型(ip4和ip6是可选的)
  参数protocol可以是:both、ipv4、ipv6
  验证时,会根据设置报错
14、models.NullBooleanField  允许为空的布尔类型
15、models.PositiveIntegerFiel  正Integer
16、models.PositiveSmallIntegerField  正smallInteger
17、models.SlugField  减号、下划线、字母、数字
18、models.SmallIntegerField  数字
  数据库中的字段有:tinyint、smallint、int、bigint
19、models.TextField  字符串=longtext
20、models.TimeField  时间 HH:MM[:ss[.uuuuuu]]
21、models.URLField  字符串,地址正则表达式
22、models.BinaryField  二进制
23、models.ImageField   图片
24、models.FilePathField 文件

  

如上那么多的字段,可大致分为 字符串、数字、时间、二进制、自增(primary_key=True)几类。

2、字段参数介绍

  • 数据库中的字段参数
null                # 是否可以为空
default             # 默认值
primary_key         # 主键
db_column           # 列名
db_index            # 索引(db_index=True)
unique              # 唯一索引(unique=True)
unique_for_date     # 只对日期索引
unique_for_month    # 只对月份索引
unique_for_year     # 只对年做索引
auto_now            # 创建时,自动生成时间
auto_now_add        # 更新时,自动更新为当前时间
 # 更新时间不支持这种
        obj = UserGroup.objects.filter(id=1).update(caption=‘CEO‘)
        obj = UserGroup.objects.filter(id=1).first()  # 自动更新时间需要这样写
        obj.caption = "CEO"
        obj.save()

  

  • 以下是只针对admin的字段参数
choices             # 作用:1、django admin中显示下拉框;2、避免连表查询
user_type_choices = (  # 数据库只存1、2、3,后面的信息存在内存里。
            (1, ‘超级用户‘),
            (2, ‘普通用户‘),
            (3, ‘普普通用户‘),
)
user_type_id = models.IntegerField(choices=user_type_choices,default=1)
blank              # django admin是否可以为空
verbose_name       # django admin显示字段中文
editable           # django admin是否可以被编辑
error_messages     # 错误信息
    # error_messages={"required":"密码不能为空",}  # 注意必须有逗号
help_text          # django admin提示
validators         # django form ,自定义错误信息

python manage.py createsuperuser    # 创建 Django 用户

  

3、Django ORM 外键操作

连表关系之一对多,models.ForeignKey(ColorDic)

models.py

  • 表关联
class UserGroup(models.Model):
    uid = models.AutoField(primary_key=True)
    caption = models.CharField(max_length=32,unique=True)
    ctime = models.DateTimeField(auto_now_add=True, null=True)
    uptime = models.DateTimeField(auto_now=True, null=True)

class UserInfo(models.Model):
    username = models.CharField(max_length=32,blank=True,verbose_name=‘用户名‘)
    password = models.CharField(max_length=60, help_text=‘pwd‘)
    email = models.CharField(max_length=60)
    test = models.EmailField(max_length=19,null=True,error_messages={‘invalid‘: ‘请输入密码‘,})
    # UserInfo表中没有user_group字段,而是 user_group_id 列 值为 uid 数字
    user_group = models.ForeignKey("UserGroup",to_field=‘uid‘)      # 外键关联 **********

  

  • 数据查询
user_list = Userinfo.objects.all()  # 获取Userinfo对象
for row in user_list:               #
    print(row.user_group_id)        # 数据库里真实存在的数据
    # user_group:代指UserGroup对象。类UserGroup对象里封装了(uid,catption,ctime,uptime)
    print(row.user_group.uid)       # 通过对象获取uid,和user_group_id一样
    print(row.user_group.caption)   # 通过对象获取caption

  

  • 创建数据

UserInfo表创建数据,怎么写呢?

models.UserInfo.objects.create(
        username=‘root1‘,
        password=‘123‘,
        email="asdfasdf",
        test="asdfasdf",
        # 第一种方式:再次查询数据库,不推荐
        # user_group = models.UserGroup.objects.filter(id=1).first()
        # 第二种方式:通过 外键字段_id
        user_group_id = 1
    )

转载来源:http://blog.csdn.net/fgf00/article/details/53678205



时间: 2024-10-09 11:46:27

Django入门4: ORM 数据库操作的相关文章

Django学习【第5篇】:Django之ORM数据库操作

django之ORM数据库操作 一.ORM介绍 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录----------------->类实例化对象 ORM的两大功能: 操作表: - 创建表 - 修改表 - 删除表 操作数据行: - 增删改查 ORM利用pymysql第三方工具链接数据库 Django没办法帮我们创建数据库,只能我们创建完之后告诉它,让django去链接 二.创建表之前的准备工作 一.自己创建数据库

Django中的ORM进阶操作

Django中的ORM进阶操作 Django中是通过ORM来操作数据库的,通过ORM可以很easy的实现与数据库的交互.但是仍然有几种操作是非常绕也特别容易混淆的.于是,针对这一块,来一个分类总结吧. 对于ORM对数据库的基本操作前面model里已经有了介绍,这里专门针对ORM的一对多.多对多.正向.反向等操作来讲解用法和注意事项. 铭记于心的两条: 在联表操作过滤查找数据时用双下划线 "__" 在取数据时用点 "." 一.一对多 首先来设计两张简单的表格,并在其中

【Django】ORM数据库操作

Django-ORM数据库操作 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录----------------->类实例化对象 ORM的两大功能: 操作表: - 创建表 - 修改表 - 删除表 操作数据行: - 增 删 改 查 ORM利用pymysql第三方工具链接数据库 Django默认的是sqlite数据库 将Django数据库修改为mysql: 1.settings.py 配置 DATABASES = {

Django-website 程序案例系列-4 ORM数据库操作

数据库表的创建: 使用mysql时注意,在setting.py中的设置: DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', #mysql的引擎 'NAME': '', #数据库名 'USER': '', #数据库用户名 'PASSWORD': '', #数据库密码 'HOST': '127.0.0.1', #数据库host 'PORT': '3306', #数据库端口 },} 还需在项目文件夹下的__init__.p

Django(三) ORM 数据库操作

比较有用 转自 http://blog.csdn.net/fgf00/article/details/53678205 一.DjangoORM 创建基本类型及生成数据库表结构 1.简介 2.创建数据库 表结构 二.Django ORM基本增删改查 1.表数据增删改查 2.表结构修改 三.Django ORM 字段类型 1.字段类型介绍 2.字段参数介绍 3.Django ORM 外键操作 一.DjangoORM 创建基本类型及生成数据库表结构 1.简介 ORM:关系对象映射.定义一个类自动生成数

Django—ORM数据库操作

---恢复内容开始--- 一.orm介绍 1 ORM即Object Relational Mapping,全称对象关系映射. 优点: 1 不用写sql,不会sql的人也可以写程序 2 开发效率高 2 缺点: 1 可能sql的效率低 3 如何使用: 如果连接mysql:在setting里配置: 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST': '127.0.0.1', 'PORT': 3306, 'USER': 'root', '

Django学习【第5篇】:Django之ORM数据库操作注意细节

自己没有记住的一点小知识(ORM查询相关) 一.多对多的正反向查询 class Class(models.Model): name = models.CharField(max_length=32,verbose_name="班级名") course = models.CharField(verbose_name="课程",max_length=32) def __str__(self): return self.name class Teacher(models.

django之ORM数据库操作

映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录----------------->类实例化对象 原文地址:https://www.cnblogs.com/heshun/p/9846718.html

Django学习手册 - sqlit数据库操作

步骤阐述:( splitDB 是Django自带的一个数据库) 1.在APP01 中的 models.py 配置DB信息  userinfo 相当于数据表的表名,而 uname.pwd 相当于 表中的两个列字段.(DB默认还会自建一个ID列) 2.在setting 中注册 app01. 3.运行命令,建立数据表,写入数据. 4.split 数据库的基本增删改查. 步骤1.在业务app01 models 文当中 写入数据表的 表字段(uname 和 pwd 这个两个字段) 步骤2.在luru的主目