模版之标签、orm多表查询

发布时间 2024-01-02 11:49:12作者: Way*yy

模版之标签

就是在模版里面使用流程控制:if、else、elseif、for等等

for标签:
	# lis是通过locals()从后端返回出来的数据
	{% for li in lis %}
		<p>{{ li }}</p>
    {% endfor %}
    # 这样我们在前端看到的就是for循环后的结果了
 	
   # 遍历字典
	{% for d in dic %}
        <p>{{ d }}</p>
    {% endfor %}
   # 遍历出来的也是key值

字典三剑客:
	{% for d in dic.items %} # 得到的是一个元组里面有key、value
        <p>{{ d }}</p>
    {% endfor %}
    
    {% for d in dic.keys %} # 得到的是key
        <p>{{ d }}</p>
    {% endfor %}
    
    {% for d in dic.values %} # 得到的是values
        <p>{{ d }}</p>
    {% endfor %}

if标签

# {% if %}会对一个变量求值,如果它的值是True(存在、不为空、且不是boolean类型的false值),对应的内容块会输出。

{% if num > 100 or num < 0 %}
    <p>无效</p>
{% elif num > 80 and num < 100 %}
    <p>优秀</p>
{% else %}
    <p>凑活吧</p>
{% endif %}

if语句支持 and 、or、==、>、<、!=、<=、>=、in、not in、is、is not判断。

with 起别名

d = {'username':'kevin','age':18,'info':'这个人有点意思','hobby':[111,222,333,{'info':'NB'}]}

{% with d.hobby.3.info as nb  %}
    <p>{{ nb }}</p>
    在with语法内就可以通过as后面的别名快速的使用到前面非常复杂获取数据的方式
    <p>{{ d.hobby.3.info }}</p>
{% endwith %}

模版的继承

"""
	你们有没有见过一些网站
	这些网站页面整体都大差不差 只是某一些局部在做变化	
"""
# 模版的继承 你自己先选好一个你要想继承的模版页面
{% extends 'home.html' %}

# 继承了之后子页面跟模版页面长的是一模一样的 你需要在模版页面上提前划定可以被修改的区域
{% block content %}
	模版内容
{% endblock %}

# 子页面就可以声明想要修改哪块划定了的区域
{% block content %}
	子页面内容	
{% endblock %}


# 一般情况下模版页面上应该至少有三块可以被修改的区域
    1.css区域
    2.html区域
    3.js区域
    {% block css %}

    {% endblock %}

    {% block content %}

    {% endblock %}

    {% block js %}

    {% endblock %}
  # 每一个子页面就都可以有自己独有的css代码 html代码 js代码
  
"""
    一般情况下 模版的页面上划定的区域越多 那么该模版的扩展性就越高
    但是如果太多 那还不如自己直接写
"""

模版的导入

"""
将页面的某一个局部当成模块的形式
哪个地方需要就可以直接导入使用即可
"""
{% include 'wasai.html' %}

模型层

测试环境搭建

在测试文件(tests)中使用django需要先配置django环境
	"""在这里写根Django没有关系的代码是直接可以写,也可以直接运行,但是只要跟django相关的都不行"""

    # 制作django环境
    import os
    import sys


    if __name__ == '__main__':
        os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'day58_dj.settings')
        import django
        django.setup()

查看原生SQL语句

使用orm时查看原生SQL语句,在配置文件中添加
	LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
        },
    },
    'loggers': {
        'django.db.backends': {
            'handlers': ['console'],
            'propagate': True,
            'level': 'DEBUG',
        },
    }
}

常见的十几种查询方式

1、# 获取第一个对象  first(
    user_obj = models.UserInfo.objects.filter().first()
    print(user_obj[0])  # UserInfo object (1)
    print(user_obj.username)  # kevin
    '''
        注意: 如果在后面使用了first方法就不能再使用下标取值
                UserInfo对象不可下标
    '''
2、# 获取最后一个对象  last()
    user_obj = models.UserInfo.objects.filter().all().last()
    print(user_obj.username)  # kevin4

3、# 直接获取数据对象,但是条件不存在就会报错 get()
	obj = models.UserInfo.objects.filter(username='kevin').get()
    print(obj)  # UserInfo object (1)
    
4、# 查询所有的数据 all()
	print(models.UserInfo.objects.all())
    
5、# 可以指定获取的数据字段 values()
    obj = models.UserInfo.objects.filter().values('username')
    # < QuerySet[{'username': 'kevin'}, {'username': 'kevin1'}, {'username': 'kevin2'}, {'username': 'kevin3'}, {'username': 'kevin4'}] >
    print(obj)

6、# values_list() 列表套元组
    obj1 = models.UserInfo.objects.values_list('username')
    print(obj1)
    # <QuerySet [('kevin',), ('kevin1',), ('kevin2',), ('kevin3',), ('kevin4',)]>
    
7、# filter 带有过滤条件的查询
    print(models.UserInfo.objects.filter(username='kevin'))
    # <QuerySet [<UserInfo: UserInfo object (1)>]>
    """
     # 查看内部封装的sql语句
     上述查看sql语句的方式  只能用于queryset对象
     只有queryset对象才能够点击query查看内部的sql语句

    """
8、# distinct 去重
    obj1 = models.UserInfo.objects.values('username').distinct()
    print(obj1)
    # < QuerySet[{'username': 'kevin'}, {'username': 'kevin1'}, {'username': 'kevin2'}, {'username': 'kevin4'}] >

9、# order_by() 升序 order_by("-") 降序
	# 升序
    obj1 = models.UserInfo.objects.order_by('age')
    for linc in obj1:
        print(linc.username) # kevin、kevin1、kevin2、kevin4、kevin3
        
    # 降序
    obj1 = models.UserInfo.objects.order_by('-age')
    for linc in obj1:
        print(linc.username)  # kevin3、kevin4、kevin2、kevin1、kevin

10、# reverse()  反转的前提是 数据已经排过序了  order_by()
    res = models.User.objects.all()
    res1 = models.User.objects.order_by('age').reverse()
    print(res,res1)

11.# count()  统计当前数据的个数
    res = models.User.objects.count()
    print(res)
12.# exclude()  排除在外
    res = models.User.objects.exclude(name='jason')
    print(res)

13.# exists()  基本用不到因为数据本身就自带布尔值  返回的是布尔值
    res = models.User.objects.filter(pk=10).exists()
    print(res)

基于双下划线的查询

基于双下划线的查询
    # 1 年龄大于35岁的数据
    res = models.UserInfo.objects.filter(age__gte=35).all()
    print(res)
    
    # 年龄小于10岁的数据 equal
    res = models.UserInfo.objects.filter(age__lte=10).all()
    print(res)
    
    # 年龄是10 或者 20 或者 30
    res = models.UserInfo.objects.filter(age__in=[10, 20, 30]).all()
    print(res)
    
    # 年龄在18到40岁之间的  首尾都要
    from table where age between 18 and 40
    res = models.UserInfo.objects.filter(age__range=[18, 40])
    print(res)
    
    # 查询出名字里面含有s的数据  模糊查询
    from table where username like '%s%'
    
    res = models.UserInfo.objects.filter(username__contains='s').all()
    print(res)
    # 用户名以s开头的
    res = models.UserInfo.objects.filter(username__startswith='s').all() # like 's%'
    res =models.UserInfo.objects.filter(username__endswith='s').all() like '%s'
    print(res)
     
    # 查询出注册时间是 2023 5月
    res = models.UserInfo.objects.filter(reg_time__month=5, reg_time__year=2023, reg_time__day=1).all()
    res = models.UserInfo.objects.filter(reg_time__month=5, reg_time__day=1).all()
    print(res)

一对多的外键字段查询

一对多的查询:
	# 图书和出版社是一对多的关系
增加一本图书
"""添加数据之前需要先在被绑定的表单中添加数据,要不然会添加失败"""
1、直接写实际字段  id
    models.Book.objects.create(title="京阿尼自传", price=100, publish_date="2023-08-01", publish_id=1)
2、虚拟字段  对象
    publish_obj = models.Publish.objects.filter(pk=2).first()
    print(publish_obj) # 上海出版社
    models.Book.objects.create(title="红楼梦", price=1000, publish_date="2008-04-25", publish=publish_obj)

3、删除 级联删除
	models.Book.objects.filter(publish_id=2).delete()

4、修改
	# 方法一:
	models.Book.objects.filter(pk=1).update(publish_id=2)
    
    # 方法二:
    publish_obj = models.Publish.objects.filter(pk=1).first()
    print(publish_obj)
    models.Book.objects.filter(pk=1).update(publish=publish_obj)