映射关系 表名<---------->类名 字段<---------->属性 表记录<-------->类示例对象
映射关系
表名<---------->类名
字段<---------->属性
表记录<-------->类示例对象
实例: 下面建立的是一个关于书的表 class Books(models.Model): bid = models.AutoField(primary_key=True) bname = models.CharField(max_length=32) bauthor = models.CharField(max_length=16) bprice = models.DecimalField(max_digits=5,decimal_places=2) bdata = models.DateField() #建立一个类,类名称就是表名,建立类必定要继承models.Model。上述实例中bid,bname就至关因而表中的字段,注意相应的参数。id能够本身写,可是必需要加上primmary_key=True,也能够不写,Django会本身添加。 #在models中建立完类以后,在命令行中执行: python manage.py makemigrations python manage.py migrate #版本不同的能够去查一下,新版本都是执行上述命令生成相应的表。 #Django默认是sqlit3的数据库,若是用的mysql能够在settings中修改参数: DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql',#mysql就是你想用的数据库 'NAME': "books",#数据库名称 "USER": "root",#用户 "PASSWORD":"",#密码 "HOST":"",#用户 "PORT":"3306"#端口 } } #执行完以后就能够在数据库中查到相应的表,第一次建立会生成不少表,用Django建立的表的名称是‘应用名+类名’(推荐使用Navcite数据库可视化工具,方便修改) #若是想查看本身的建立的表的sql命令,能够在setting中添加: LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'console':{ 'level':'DEBUG', 'class':'logging.StreamHandler', }, }, 'loggers': { 'django.db.backends': { 'handlers': ['console'], 'propagate': True, 'level':'DEBUG', }, } } #这样执行的时候能够在终端显示sql命令。
实例:
下面建立的是一个关于书的表
class Books(models.Model):
bid = models.AutoField(primary_key=True)
bname = models.CharField(max_length=32)
bauthor = models.CharField(max_length=16)
bprice = models.DecimalField(max_digits=5,decimal_places=2)
bdata = models.DateField()
#建立一个类,类名称就是表名,建立类必定要继承models.Model。上述实例中bid,bname就至关因而表中的字段,注意相应的参数。id能够本身写,可是必需要加上primmary_key=True,也能够不写,Django会本身添加。
#在models中建立完类以后,在命令行中执行:
python manage.py makemigrations
python manage.py migrate
#版本不同的能够去查一下,新版本都是执行上述命令生成相应的表。
#Django默认是sqlit3的数据库,若是用的mysql能够在settings中修改参数:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',#mysql就是你想用的数据库
'NAME': "books",#数据库名称
"USER": "root",#用户
"PASSWORD":"",#密码
"HOST":"",#用户
"PORT":"3306"#端口
}
}
#执行完以后就能够在数据库中查到相应的表,第一次建立会生成不少表,用Django建立的表的名称是‘应用名+类名’(推荐使用Navcite数据库可视化工具,方便修改)
#若是想查看本身的建立的表的sql命令,能够在setting中添加:
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'console':{
'level':'DEBUG',
'class':'logging.StreamHandler',
},
},
'loggers': {
'django.db.backends': {
'handlers': ['console'],
'propagate': True,
'level':'DEBUG',
},
}
}
#这样执行的时候能够在终端显示sql命令。
#每一个字段有一些特有的参数,例如,CharField须要max_length参数来指定VARCHAR数据库字段的大小。还有一些适用于全部字段的通用参数。 这些参数在文档中有详细定义,这里咱们只简单介绍一些最经常使用的: 1.null 若是为True,Django将用NULL在书库中存储控制。默认是False。 2.blank 若是为True,该字段永续不填。默认为False,要注意,这与NULL不一样。Null纯粹是数据库范畴的,而blank是数据验证的,若是一个字段的Blank为True,表单的验证将容许该字段是空值,若是blank=true,该字段就是必填的。 3.default 字段的默认值。能够是一个值或者为调用对象,若是可调用 ,每有新对象被建立它都会被调用。 4.primary_key 若是为True,那么这个字段就是模型的主键。若是你没有指定任何一个字段的primary_key=True,Django 就会自动添加一个IntegerField字段作为主键,因此除非你想覆盖默认的主键行为,不然不必设置任何一个字段的primary_key=True。 5.unique 若是该值设置为 True, 这个数据字段的值在整张表中必须是惟一的。 6.choices 由二元组组成的一个可迭代的帝乡,用来给字段提供选择项。若是设置了choices,默认的表单讲师一个选择框而不是标准的文本框,并且这个选择框的选项就是choices中的选项。 #示例: YEAR_IN_SCHOOL_CHOICES = ( ('FR', 'Freshman'), ('SO', 'Sophomore'), ('JR', 'Junior'), ('SR', 'Senior'), ('GR', 'Graduate'), ) 7.auto_now 和 auto_now_add auto_now 自动建立---不管添加或修改,都是当前操做的时间, auto_now_add 自动建立---永远是建立时的时间 8.auto_created=False 自动建立 9.db_index =True 数据库索引 10.max_length 最大长度
#每一个字段有一些特有的参数,例如,CharField须要max_length参数来指定VARCHAR数据库字段的大小。还有一些适用于全部字段的通用参数。 这些参数在文档中有详细定义,这里咱们只简单介绍一些最经常使用的:
1.null
若是为True,Django将用NULL在书库中存储控制。默认是False。
2.blank
若是为True,该字段永续不填。默认为False,要注意,这与NULL不一样。Null纯粹是数据库范畴的,而blank是数据验证的,若是一个字段的Blank为True,表单的验证将容许该字段是空值,若是blank=true,该字段就是必填的。
3.default
字段的默认值。能够是一个值或者为调用对象,若是可调用 ,每有新对象被建立它都会被调用。
4.primary_key
若是为True,那么这个字段就是模型的主键。若是你没有指定任何一个字段的primary_key=True,Django 就会自动添加一个IntegerField字段作为主键,因此除非你想覆盖默认的主键行为,不然不必设置任何一个字段的primary_key=True。
5.unique
若是该值设置为 True, 这个数据字段的值在整张表中必须是惟一的。
6.choices
由二元组组成的一个可迭代的帝乡,用来给字段提供选择项。若是设置了choices,默认的表单讲师一个选择框而不是标准的文本框,并且这个选择框的选项就是choices中的选项。
#示例:
YEAR_IN_SCHOOL_CHOICES = (
('FR', 'Freshman'),
('SO', 'Sophomore'),
('JR', 'Junior'),
('SR', 'Senior'),
('GR', 'Graduate'),
)
7.auto_now 和 auto_now_add
auto_now 自动建立---不管添加或修改,都是当前操做的时间,
auto_now_add 自动建立---永远是建立时的时间
8.auto_created=False
自动建立
9.db_index =True
数据库索引
10.max_length
最大长度
a=models.AutoField #自增列=int() #若是没有的话,默认会生成一个名称为id的列,若是要显示的自定义一个自增列,必须讲给列设置主键 primary_key=true b=models.CharField #字符串字段 #必须有max_length参数 c=models.BooleanField #布尔类型=tinyint(1) #不能为空blank=True d=models.CommaSeparatedIntegerField #用逗号分割的数字=varchar #继承CharField,因此必须有max_length参数 e=models.DateField #日期类型的Date #对于参数,auto_now=True则每次跟新都是更新这个时间;auto_now_add则只是第一次建立添加,以后的更新将再也不改变 f=models.DecimalField #十进制小数的类型 #必须制定整数位max_digits(总位数长度)和小数位decimal_places g=models.EmailField #字符串诶性(正则表达式邮箱)=varchar #对字符串进行正则表达式 h=models.IntegerField #整形 i=models.TimeField #时间 HH:MM[:ss[.uuuuuu]] j=models.TextField #字符串=longtext k=models.ImageField #图片 l=models.FilePathField #文件
a=models.AutoField #自增列=int()
#若是没有的话,默认会生成一个名称为id的列,若是要显示的自定义一个自增列,必须讲给列设置主键 primary_key=true
b=models.CharField #字符串字段
#必须有max_length参数
c=models.BooleanField #布尔类型=tinyint(1)
#不能为空blank=True
d=models.CommaSeparatedIntegerField #用逗号分割的数字=varchar
#继承CharField,因此必须有max_length参数
e=models.DateField #日期类型的Date
#对于参数,auto_now=True则每次跟新都是更新这个时间;auto_now_add则只是第一次建立添加,以后的更新将再也不改变
f=models.DecimalField #十进制小数的类型
#必须制定整数位max_digits(总位数长度)和小数位decimal_places
g=models.EmailField #字符串诶性(正则表达式邮箱)=varchar
#对字符串进行正则表达式
h=models.IntegerField #整形
i=models.TimeField #时间 HH:MM[:ss[.uuuuuu]]
j=models.TextField #字符串=longtext
k=models.ImageField #图片
l=models.FilePathField #文件
#添加普通字段 #方式一 books_obj=models.Books(bname="追风筝的人",bauthor="卡勒德·胡赛尼",bprice="111.88",bdata="2003-10-10") books_obj.save() #方式二 books_obj=models.Books.objects.create(bname="追风筝的人",bauthor="卡勒德·胡赛尼",bprice="111.88",bdata="2003-10-10") #注:id能够不添加,数据库会自动添加
#添加普通字段
#方式一
books_obj=models.Books(bname="追风筝的人",bauthor="卡勒德·胡赛尼",bprice="111.88",bdata="2003-10-10")
books_obj.save()
#方式二
books_obj=models.Books.objects.create(bname="追风筝的人",bauthor="卡勒德·胡赛尼",bprice="111.88",bdata="2003-10-10")
#注:id能够不添加,数据库会自动添加
#方式一 book_obj=models.Books.objects.filter(bid=i) book_obj.bname="天才在左疯子在右" book_obj.bauthor="高铭" book_obj.bdata="2010-10-10" book_obj.bprice="28.60" book_obj.save() #方式二 models.Books.objects.filter(id=id).update(bname="天才在左疯子在右",bauthor="高铭",bdata="2010-10-10",bprice="28.60") #此外,update()方法对于任何结果集(QuerySet)均有效,这意味着你能够同时更新多条记录update()方法会返回一个整型数值,表示受影响的记录条数。
#方式一
book_obj=models.Books.objects.filter(bid=i)
book_obj.bname="天才在左疯子在右"
book_obj.bauthor="高铭"
book_obj.bdata="2010-10-10"
book_obj.bprice="28.60"
book_obj.save()
#方式二
models.Books.objects.filter(id=id).update(bname="天才在左疯子在右",bauthor="高铭",bdata="2010-10-10",bprice="28.60")
#此外,update()方法对于任何结果集(QuerySet)均有效,这意味着你能够同时更新多条记录update()方法会返回一个整型数值,表示受影响的记录条数。
#删除方法就是 delete()。它运行时当即删除对象而不返回任何值。 #删除方法就是 delete()。它运行时当即删除对象而不返回任何值。 models.Books.objects.filter(id=id).delete()
#删除方法就是 delete()。它运行时当即删除对象而不返回任何值。
#删除方法就是 delete()。它运行时当即删除对象而不返回任何值。
models.Books.objects.filter(id=id).delete()
#查询相关的参数 <1> all(): 查询全部结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个, 若是符合筛选条件的对象超过一个或者没有都会抛出错误。 <5> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象 <4> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后获得的并非一系列 model的实例化对象,而是一个可迭代的字典序列 <9> values_list(*field): 它与values()很是类似,它返回的是一个元组序列,values返回的是一个字典序列 <6> order_by(*field): 对查询结果排序 <7> reverse(): 对查询结果反向排序 <8> distinct(): 从返回结果中剔除重复纪录 <10> count(): 返回数据库中匹配查询(QuerySet)的对象数量。 <11> first(): 返回第一条记录 <12> last(): 返回最后一条记录 <13> exists(): 若是QuerySet包含数据,就返回True,不然返回False #双下划綫查询 models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值 models.Tb1.objects.filter(id__in=[11, 22, 33]) # 获取id等于十一、2二、33的数据 models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in models.Tb1.objects.filter(name__contains="ven") models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感 models.Tb1.objects.filter(id__range=[1, 2]) # 范围bettwen and
#查询相关的参数
<1> all(): 查询全部结果
<2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象
<3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,
若是符合筛选条件的对象超过一个或者没有都会抛出错误。
<5> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象
<4> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后获得的并非一系列
model的实例化对象,而是一个可迭代的字典序列
<9> values_list(*field): 它与values()很是类似,它返回的是一个元组序列,values返回的是一个字典序列
<6> order_by(*field): 对查询结果排序
<7> reverse(): 对查询结果反向排序
<8> distinct(): 从返回结果中剔除重复纪录
<10> count(): 返回数据库中匹配查询(QuerySet)的对象数量。
<11> first(): 返回第一条记录
<12> last(): 返回最后一条记录
<13> exists(): 若是QuerySet包含数据,就返回True,不然返回False
#双下划綫查询
models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值
models.Tb1.objects.filter(id__in=[11, 22, 33]) # 获取id等于十一、2二、33的数据
models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in
models.Tb1.objects.filter(name__contains="ven")
models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
models.Tb1.objects.filter(id__range=[1, 2]) # 范围bettwen and