zoukankan      html  css  js  c++  java
  • 自连接

    自连接

    • 对于地区信息,属于一对多关系,使用一张表,存储所有的信息
    • 类似的表结构还应用于分类信息,可以实现无限级分类
    • 新建模型AreaInfo,生成迁移
    class AreaInfo(models.Model):
        atitle = models.CharField(max_length=20)
        aParent = models.ForeignKey('self', null=True, blank=True)
    
    • 访问关联对象
    上级对象:area.aParent
    下级对象:area.areainfo_set.all()
    
    • 加入测试数据(在workbench中,参见“省市区mysql.txt”)
    • 在booktest/views.py中定义视图area
    from models import AreaInfo
    def area(request):
        area = AreaInfo.objects.get(pk=130100)
        return render(request, 'booktest/area.html', {'area': area})
    
    • 定义模板area.html
    <!DOCTYPE html>
    <html>
    <head>
        <title>地区</title>
    </head>
    <body>
    当前地区:{{area.atitle}}
    <hr/>
    上级地区:{{area.aParent.atitle}}
    <hr/>
    下级地区:
    <ul>
        { %for a in area.areainfo_set.all%}
        <li>{{a.atitle}}</li>
        { %endfor%}
    </ul>
    </body>
    </html>
    
    • 在booktest/urls.py中配置一个新的urlconf
    urlpatterns = [
        url(r'^area/$', views.area, name='area')
    ]

    总结

    • 使用mysql数据库
    • 定义模型,生成迁移
    • 定义管理器
    • 查询
    • 自连接
     
  • 相关阅读:
    [CQOI2006]凸多边形
    NOIP后省选集训前文化课划水记
    FFT字符串匹配
    ghj1222的代码规范
    博弈论
    P1350 车的放置
    P2110 欢总喊楼记
    虫食算
    3192: [JLOI2013]删除物品
    逛公园
  • 原文地址:https://www.cnblogs.com/Smalllv/p/9127656.html
Copyright © 2011-2022 走看看