02-django的基本使用(模型)

2018-04-28  本文已影响60人  B头
  1. ORM框架(将类和数据表进行对应起来)

    1. Object:对象-类

    2. Mapping:映射

    3. Relations 关系

    4. 通过类和对象操作对应的数据表,不需要写SQL语句.

    5. 另外一个重点的作用:根据设计的类生成数据库中的表

  2. 在models.py(模型类)--模型类设计和表生成

    1. 设计和表对应的类
    class BookInfo(models.Model):
    btitle = models.CharField(max_length=200) 
    
  3. 生成数据库的步骤

    1. 生成迁移文件
      python manage.py makemigrations
    2. 执行迁移生成表
      python manage.py migrate
  1. 通过模型类操作数据表

    1. 进入项目shell的命令
      python mange.py shell
    2. 导入刚刚创建的模型类 xxx
    3. 然后创建一个对象
      b = xxx()
    4. 增加实例属性
      b.btitle = "天龙八部"
      xxxx各种增加实例属性
    5. 调用一个方法,保存数据
      b.save()
    6. 查询数据
      b2= BookInfo.objects.get(id=1)
      b2.btitle
      1. 查询所有图书数据
        BookInfo.objects.all()
    7. 修改数据
      b2.btitle = "laofuzi"
      b2.save()
    8. 删除数据
      b2.delete()
  2. 模型类关系和关系查询(一对多的关系)

    1. 创建另外一个模型类

      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")
      
      1. 一对多是什么关系?

        1. 首先一对多不是一个表中的一个列对应另一个表中的多个列,列是不能够一对多的!这里的一对多是是指行的对应!

        一对多关系,一般是一个表的主键对应另一个表的非主键,主键的值是不能重复的,而非主键值是可以重复的,
        一个主键值对应另一个表的非主键的值,那么就只有一个值对一个值或一个值对多个值两种可能,故称一对多。
        而在一对一关系中,一般是主键对应主键,那么显然就只有一个值对一个值的可能,故称一对一。

    2. 生成迁移文件 (前面的模型类生成的迁移文件不能删除,如果是一对多是有依赖关系的!),并且执行.

    3. 重新进入shell

      1. 导入两个模型类
      2. 步骤如第一个
      3. 第二个是创建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(有多查一)
      
      
    4. 获得关联集合:返回当前book对象的所有hero(由一查多)
      b.heroinfo_set.all()

  3. django后台管理(主要是用于管理数据库里面的数据表)

    1. 本地化

      1. 语言和时区的本地化

      2. 修改 settings.py文件

        1. LANGUAGE_CODE = 'zh-hans'
        2. TIME_ZONE = 'Asia/Shanghai'
    2. 创建管理员

      1. python manage.py createsuperuser
        admin
        77@qq.com
        admin
    3. 注册模型类

      1. 在应用下的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)

    4. 自定义管理页面

      1. 自定义模型管理类

        直接再admin.py下面添加代码
        class BookInfoAdmin(admin.ModelAdmin):
        list_display = ['id','btitle',,,,]

      2. 修改注册模块类,同样在admin.py里面修改
        admin.site.register(BookInfo,BookInfoAdmin)

上一篇下一篇

猜你喜欢

热点阅读