Django-ORM模型层语法(二)之必知必会13条

必知必会13条

django自带的sqlite3数据库对日期格式不是很敏感 处理的时候容易出错

settings.py

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'orm1',
        "USER":'root',
        'PASSWORD':'123456',
        'HOST':'127.0.0.1',
        'PORT':3306,
        'CHARSET':'utf8',
    }
}

init.py

import pymysql
pymysql.install_as_MySQLdb()

models.py

from django.db import models


# Create your models here.
class User(models.Model):
	name = models.CharField(max_length=32)
	age = models.IntegerField()
	register_time = models.DateField()  # 年月日

	def __str__(self):
		return '对象:%s' % self.name

Terminal

python manage.py makemigrations
python manage.py migrate

app01/tests.py

"""
当你只是想测试django中的某一个py文件内容 那么你可以不用书写前后端交互的形式
而是直接写一个测试脚本即可
脚本代码无论是写在应用下的tests.py还是自己单独开设py文件都可以
"""
# 测试环境的准备 去manage.py中拷贝前四行代码 然后自己写两行
import os

if __name__ == "__main__":
    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "orm1.settings")
    import django
    django.setup()
    # 在这个代码块的下面就可以测试django里面的单个py文件了
    # 所有的代码都必须等待环境准备完毕之后书写
    from app01 import models

# 必知必会13条
    # 1.all() 查询所有 queryset 类似于列表 
    
    # 2.filter() 带有过滤条件的查询  结果为queryset类型数据
    
    # 3.get() 直接拿数据对象,但是条件不存在直接报错
    
    # 4.first() 拿queryset里面的第一个元素
    res = models.User.objects.all().first()
    print(res)
    
    # 5.last() 拿queryset里面的最后一个元素
    res = models.User.objects.all().last()
    print(res)
    
    # 6.values()  可以指定获取的数据字段  列表套字典
    res = models.User.objects.values('name')
    print(res) # <QuerySet [{'name': 'steven'}, {'name': 'baby'}]>
    
    # 7.values_list() 列表套元祖
    res = models.User.objects.values_list('name','age')
    print(res) # <QuerySet [('steven', 18), ('baby', 20)]>
    print(res.query) # 查看内部封装的sql语句
    '''
    上述查看sql语句的方式,只能用于queryset对象,只有queryset对象才能点击query查看内部的sql语句
    '''
    
    # 8.distinct() 去重
    res = models.User.objects.values('name','age').distinct()
    print(res)
    '''
    去重一定要是一模一样的数据,如果带有主键那么肯定不一样,往后的查询中一定不要忽略主键
    '''
    
    # 9.oder_by
    res = models.User.objects.order_by('age') # 默认升序
    res = models.User.objects.order_by('-age') # 降序
    print(res)
    
    # 10.reverse() 反转的前提是数据已经排序了
    res = models.User.objects.order_by('age').reverse()
    print(res)
    
    # 11.count() 统计当前数据的个数
    res = models.User.objects.count()
    print(res)
    
    # 12.exclude() 排除在外
    res= models.User.objects.exclude(name='steven')
    print(res)
    
    # 13.exists() 基本用不到,数据本身就自带布尔值,返回布尔值
    res = models.User.objects.filter(pk=4).exists()
    print(res) # True

查看内部sql语句的方式

方式1

    res = models.User.objects.values_list('name','age')
    print(res.query) # 查看内部封装的sql语句
    # queryset对象才能够点击query查看内部的sql语句

方式2:所有的sql语句都能查看

# 去配置文件settings.py中配置一下即可
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console':{
            'level':'DEBUG',
            'class':'logging.StreamHandler',
        },
    },
    'loggers': {
        'django.db.backends': {
            'handlers': ['console'],
            'propagate': True,
            'level':'DEBUG',
        },
    }
}
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值