必知必会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',
},
}
}