必知必会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) # # 7.values_list() 列表套元祖 res = models.User.objects.values_list('name','age') print(res) # 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', }, } }