首页 > 学院 > 开发设计 > 正文

Django-模型(数据库)

2019-11-07 23:20:45
字体:
来源:转载
供稿:网友

系统环境:Win7 bit64 Anaconda2

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

1.新建项目和app

django-admin.py startPRoject learn_models # 新建一个项目cd learn_models # 进入到该项目的文件夹django-admin.py startapp people # 新建一个 people 应用(app)

将people加入settings.py中。

2.新建Person类

打开people/models.py,修改代码如下:

from django.db import modelsclass Person(models.Model): name = models.CharField(max_length=30) age = models.IntegerField()

我们新建了一个Person类,继承自models.Model, 一个人有姓名和年龄。这里用到了两种Field。

3.同步数据库

ython manage.py syncdb # 进入 manage.py 所在的那个文件夹下输入这个命令注意:Django 1.7 及以上的版本需要用以下命令python manage.py makemigrationspython manage.py migrate

新建了people_person表。

4.调用数据表

打开shell,导入Person类,用Django提供的API调用数据。新建一个person对象,用Person.objects.create

$ python manage.py shell>>> from people.models import Person>>> Person.objects.create(name="WeizhongTu", age=24)<Person: Person object>>>>

查询person类对象,用Person.objects.get

>>> Person.objects.get(name="WeizhongTu")<Person: Person object>>>>

查询返回内容没有显示person对象的详细信息,修改models.py,返回person的姓名 `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``

“` 重新同步数据库,查询获得name。

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

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

p = Person(name=”WZ”, age=23)

p.save()

p = Person(name=”TWZ”)

p.age = 23

p.save()

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

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

获取对象有以下方法:

Person.objects.all()

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

Person.objects.get(name=name)

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

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

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

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

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

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

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

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

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

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

参考:http://www.ziqiangxuetang.com/django/django-models.html


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表