系统环境:Win7 bit64 Anaconda2
Django版本:1.8.16 Django的模型(models)是与数据库相关的,所以与数据库相关代码写在models.py中。Django 支持 sqlite3, MySQL, PostgreSQL等数据库,只需要在settings.py中配置即可,不用更改models.py中的代码,丰富的API极大的方便了使用。
将people加入settings.py中。
打开people/models.py,修改代码如下:
from django.db import modelsclass Person(models.Model): name = models.CharField(max_length=30) age = models.IntegerField()我们新建了一个Person类,继承自models.Model, 一个人有姓名和年龄。这里用到了两种Field。
新建了people_person表。
打开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)
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
新闻热点
疑难解答