02-django的基本使用(模型)
-
ORM框架(将类和数据表进行对应起来)
-
Object:对象-类
-
Mapping:映射
-
Relations 关系
-
通过类和对象操作对应的数据表,不需要写SQL语句.
-
另外一个重点的作用:根据设计的类生成数据库中的表
-
-
在models.py(模型类)--模型类设计和表生成
- 设计和表对应的类
class BookInfo(models.Model): btitle = models.CharField(max_length=200)
-
生成数据库的步骤
- 生成迁移文件
python manage.py makemigrations - 执行迁移生成表
python manage.py migrate
- 生成迁移文件
-
通过模型类操作数据表
- 进入项目shell的命令
python mange.py shell - 导入刚刚创建的模型类 xxx
- 然后创建一个对象
b = xxx() - 增加实例属性
b.btitle = "天龙八部"
xxxx各种增加实例属性 - 调用一个方法,保存数据
b.save() - 查询数据
b2= BookInfo.objects.get(id=1)
b2.btitle-
查询所有图书数据
BookInfo.objects.all()
-
查询所有图书数据
- 修改数据
b2.btitle = "laofuzi"
b2.save() - 删除数据
b2.delete()
- 进入项目shell的命令
-
模型类关系和关系查询(一对多的关系)
-
创建另外一个模型类
class HeroInfo(models.Model): hname = models.CharField(max_length=20) hgender = models.BooleanField(default=False) hcomment = models.CharField(max_length=20) #关系属性 hbook 建立图书类和英雄人物类之间的一对多关系 #关系属性对应的表的字段名格式:关系属性名_id ##用自己的话,就是,在这个表的这个字段建议一个外键映射 hbook = models.ForeignKey("BookInfo")
-
一对多是什么关系?
- 首先一对多不是一个表中的一个列对应另一个表中的多个列,列是不能够一对多的!这里的一对多是是指行的对应!
一对多关系,一般是一个表的主键对应另一个表的非主键,主键的值是不能重复的,而非主键值是可以重复的,
一个主键值对应另一个表的非主键的值,那么就只有一个值对一个值或一个值对多个值两种可能,故称一对多。
而在一对一关系中,一般是主键对应主键,那么显然就只有一个值对一个值的可能,故称一对一。
-
-
生成迁移文件 (前面的模型类生成的迁移文件不能删除,如果是一对多是有依赖关系的!),并且执行.
-
重新进入shell
- 导入两个模型类
- 步骤如第一个
- 第二个是创建HeroInfo实例.
from register.models import BookInfo,HeroInfo b = BookInfo() b.btitle = "天龙八部" b.save() h = HeroInfo() h.title='段誉' ##重点 h.book = b ##b就是刚刚实例化 BookInfo模型类的实例. h.save() h.hbook(有多查一)
-
获得关联集合:返回当前book对象的所有hero(由一查多)
b.heroinfo_set.all()
-
-
django后台管理(主要是用于管理数据库里面的数据表)
-
本地化
-
语言和时区的本地化
-
修改 settings.py文件
- LANGUAGE_CODE = 'zh-hans'
- TIME_ZONE = 'Asia/Shanghai'
-
-
创建管理员
- python manage.py createsuperuser
admin
77@qq.com
admin
- python manage.py createsuperuser
-
注册模型类
- 在应用下的admin.py中注册模型类
在admin.py中编辑
from register.models import BookInfo
admin.site.register(BookInfo)
然后再django的管理后台可以查看数据了.
其实相当于 BookInfo.objects.get(btitle='天龙八部')
其实可以在models.py里面对应的数据表类,重新编辑一下
def str(self):
xxx如果需要添加多个模型类到后台去管理,一次写admin,例如是这样
admin.site.register(HeroInfo) - 在应用下的admin.py中注册模型类
-
自定义管理页面
-
自定义模型管理类
直接再admin.py下面添加代码
class BookInfoAdmin(admin.ModelAdmin):
list_display = ['id','btitle',,,,] -
修改注册模块类,同样在admin.py里面修改
admin.site.register(BookInfo,BookInfoAdmin)
-
-