Django 模型(数据库)

Stella981
• 阅读 515

Django 模型是与数据库相关的,与数据库相关的代码一般写在 models.py 中,Django 支持 sqlite3, MySQL, PostgreSQL等数据库,只需要在settings.py中配置即可,不用更改models.py中的代码,丰富的API极大的方便了使用。

本节的最后有源代码,但建议初学者按照代码操作,有问题再下载源代码和自己的代码进行比较。

多动手,这是学习编程最好的方法!

1. 新建项目和应用

1

2

3

django-admin.py startproject learn_models  # 新建一个项目

cd  learn_models  # 进入到该项目的文件夹

django-admin.py startapp people  # 新建一个 people 应用(app)

补充:新建app也可以用 python manage.py startapp people, 需要指出的是,django-admin.py 是安装Django后多出的一个命令,并不是运行的当前目录下的django-admin.py(当前目录下也没有),但创建项目会生成一个 manage.py 文件。

那project和app什么关系呢?

一个项目一般包含多个应用,一个应用也可以用在多个项目中。

2. 添加应用

将我们新建的应用(people)添加到 settings.py 中的 INSTALLED_APPS中,也就是告诉Django有这么一个应用。

1

2

3

4

5

6

7

8

9

10

INSTALLED_APPS  =  (

'django.contrib.admin' ,

'django.contrib.auth' ,

'django.contrib.contenttypes' ,

'django.contrib.sessions' ,

'django.contrib.messages' ,

'django.contrib.staticfiles' ,

'people' ,

)

3. 修改models.py

我们打开 people/models.py 文件,修改其中的代码如下:

1

2

3

4

5

6

from  django.db  import  models

class  Person(models.Model):

name  =  models.CharField(max_length = 30 )

age  =  models.IntegerField()

我们新建了一个Person类,继承自models.Model, 一个人有姓名和年龄。

这里用到了两种Field,更多Field类型可以参考教程最后的链接。

4. 创建数据表

我们来同步一下数据库(我们使用默认的数据库 SQLite3,无需配置)

1

2

3

4

5

6

7

8

先  cd  进入 manage.py 所在的那个文件夹下,输入下面的命令

# Django 1.6.x 及以下

python manage.py syncdb

# Django 1.7 及以上的版本需要用以下命令

python manage.py makemigrations

python manage.py migrate

Django 1.6.x 以下版本 显示大概如下:

Django 模型(数据库)

Django 1.7.x 以上版本的同学会看到

Django 模型(数据库)

我们会看到,Django生成了一系列的表,也生成了我们新建的people_person这个表,那么如何使用这个表呢?

5. 使用 Django 提供的 QuerySet API

Django提供了丰富的API, 下面演示如何使用它。

1

2

3

4

5

6

$ python manage.py shell

>>>  from  people.models  import  Person

>>> Person.objects.create(name = "WeizhongTu" , age = 24 )

<Person: Person  object >

>>>

我们新建了一个用户WeizhongTu 那么如何从数据库是查询到它呢?

1

2

3

>>> Person.objects.get(name = "WeizhongTu" )

<Person: Person  object >

>>>

我们用了一个 .objects.get() 方法查询出来符合条件的对象,但是大家注意到了没有,查询结果中显示<Person: **Person object**>,这里并没有显示出与WeizhongTu的相关信息,如果用户多了就无法知道查询出来的到底是谁,查询结果是否正确,我们重新修改一下 people/models.py

name 和 age 等字段中不能有 __(双下划线,因为在Django QuerySet API中有特殊含义(用于关系,包含,不区分大小写,以什么开头或结尾,日期的大于小于,正则等)

也不能有Python中的关键字,name 是合法的,student_name 也合法,但是student__name不合法,try, class, continue 也不合法,因为它是Python的关键字( import keyword; print(keyword.kwlist) 可以打出所有的关键字)

1

2

3

4

5

6

7

8

9

10

from  django.db  import  models

class  Person(models.Model):

name  =  models.CharField(max_length = 30 )

age  =  models.IntegerField()

def  __unicode__( self ):

# 在Python3中使用 def __str__(self):

return  self .name

按 CTRL + C 退出当前的 Python shell, 重复上面的操作,我们就可以看到:

Django 模型(数据库)

新建一个对象的方法有以下几种:

  1. Person.objects.create(name=name,age=age)

  2. p = Person(name="WZ", age=23)

    p.save()

  3. p = Person(name="TWZ")

    p.age = 23

    p.save()

  4. Person.objects.get_or_create(name="WZT", age=23)

    这种方法是防止重复很好的方法,但是速度要相对慢些,返回一个元组,第一个为Person对象,第二个为True或False, 新建时返回的是True, 已经存在时返回False.

获取对象有以下方法:

  1. Person.objects.all()

  2. Person.objects.all()[:10] 切片操作,获取10个人,不支持负索引,切片可以节约内存

  3. Person.objects.get(name=name)

    get是用来获取一个对象的,如果需要获取满足条件的一些人,就要用到filter

  4. Person.objects.filter(name="abc")  # 等于Person.objects.filter(name__exact="abc") 名称严格等于 "abc" 的人

  5. Person.objects.filter(name__iexact="abc")  # 名称为 abc 但是不区分大小写,可以找到 ABC, Abc, aBC,这些都符合条件

  6. Person.objects.filter(name__contains="abc")  # 名称中包含 "abc"的人

  7. Person.objects.filter(name__icontains="abc")  #名称中包含 "abc",且abc不区分大小写

  8. Person.objects.filter(name__regex="^abc")  # 正则表达式查询

  9. Person.objects.filter(name__iregex="^abc")  # 正则表达式不区分大小写

    filter是找出满足条件的,当然也有排除符合某条件的

  10. Person.objects.exclude(name__contains="WZ")  # 排除包含 WZ 的Person对象

  11. Person.objects.filter(name__contains="abc").exclude(age=23)  # 找出名称含有abc, 但是排除年龄是23岁的

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Java修道之路,问鼎巅峰,我辈代码修仙法力齐天
<center<fontcolor00FF7Fsize5face"黑体"代码尽头谁为峰,一见秃头道成空。</font<center<fontcolor00FF00size5face"黑体"编程修真路破折,一步一劫渡飞升。</font众所周知,编程修真有八大境界:1.Javase练气筑基2.数据库结丹3.web前端元婴4.Jav
KlausMecial KlausMecial
2年前
Django的安装与简易使用
Django的安装与简易使用1.Django的简介Django是有Python编写的一个开源代码Web应用框架(网址:https://github.com/django/django)。他是基于MTV模式,其本质与MVC是一样的。具体是:1.M代表模型(Model):负责业务对象和数据库的关系映射(ORM)2.T代表模板(Template):负责
陈占占 陈占占
2年前
Django 通过 admin 操作 MySQL数据库 ,审核功能加储存记录
1.创建MySQL数据库moderate表和moderatelog(储存记录)表2.Django映射(1)inspectdb创建的表(2)复制红色的框框的内容,粘贴到models.py文件可以加下面的代码或者不加也行,加的话要映射一下verbosename"Moderate"首页列表的显示名称verbosenameplura
陈占占 陈占占
2年前
Django 登入,注册,密码重置
先创建Django项目:配置settings.py和MySQL我不说了,自己网上配置xiangmu.js文件我的MySQL:链接MySQL,映射数据库我就不说了我是把MySQL的表给映射过来的【inspectdb表名】复制到models.py文件里,然后映射我的models.py文件:fromdjango.dbimportmodels
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
2年前
Django中数据库表的关联与创建(语言:python)
首先选择选用的数据库,(本人选用django(1.11.8版本))在主项目settings中操作如下:DATABASES{'default':{'ENGINE':'django.db.backends.mysql','NAME':'fruitday',
Stella981 Stella981
2年前
Django连接Mysql数据库
Mysql数据库具有灵活,轻量级易操作的优势,因此我选择使用mysql作为服务器的数据库。python的Django如果要操作数据库,需要与数据库建立连接,在此之后才可以对数据库进行操作Django项目默认使用的数据库是sqlite3,首先我们需要将数据库配置更改为mysql在项目根模块的\\newpro\\settings.py中,我们可以查询
陈占占 陈占占
1年前
Django执行迁移命令,MySQL数据库无法生成对应的数据表
Djangomakemigrations可以执行:迁移文件也在:Djangomigrate可以执行:MySQL数据库只能生成系统自带的数据库:原因:models.py文件中的managedFalse,如果设置为False,Django将不会为当前model模型创建或者删除数据库表。解决方法:把managedTrue或者删除managed。