美文网首页
02-django的基本使用(模型)

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

作者: B头 | 来源:发表于2018-04-28 17:55 被阅读60次
    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)

    相关文章

      网友评论

          本文标题:02-django的基本使用(模型)

          本文链接:https://www.haomeiwen.com/subject/djfnlftx.html