Django之ORM单表操作:数据库正反向迁移、测试环境搭建、单表查询关键字、双下划线、外键字段增删改查

本文介绍了Django中的ORM单表操作,包括数据库迁移、测试环境搭建、打印SQL语句的方法,并详细讲解了各种查询关键字如filter(), get(), all(), values(), order_by(), count(), distinct(), exclude(), reverse()等的使用,以及双下划线和外键字段的操作。" 75426147,5730416,Qt配置QSS语法高亮,"['Qt', 'QSS', '编辑器', '文本编辑', 'Qt加载QSS']
摘要由CSDN通过智能技术生成


一、 数据库正向与反向迁移

正向迁移(将django中的类导入到MySQL中变成表)
	python3 manage.py makemigrations
    python3 manage.py migrate
反向迁移
	python3 manage.py inspectdb

二、 Django脚本测试环境搭建

django默认情况下是不允许单独使用某个功能部分(models.py)

django测试环境搭建 : 
# 方式1:任意创建一个py文件,eg:test.py 在该文件内书写固定的配置

1.要么自己新建一个py文件
2.要么使用自带的tests文件

在该文件内书写固定的配置,如下:
import os
if __name__ == "__main__":
    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "day47.settings")
    import django
    django.setup()
    # 测试代码

# 方式2:直接使用pycharm提供的python console

三、 Django终端打印SQL语句

# 1 queryset对象.query
# 2 通过日志,如下,配置到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',
        },
    }
}

配置好之后,再执行任何对数据库进行操作的语句时,会自动将Django执行的sql语句打印到pycharm终端上

补充:

  • 除了配置外,还可以通过一点.query即可查看查询语句,具体操作如下:

在这里插入图片描述

四、 单表查询关键字

准备书籍表

# models.py
class Books(models.Model):
    title = models.CharField(verbose_name='书名',max_length=32)
    price = models.CharField(verbose_name='价格',max_length=32)
    publish_time = models.DateTimeField(verbose_name='日期',auto_now_add=True)
    
     def __str__(self):  # 改变对象的字符串显示,打印对象自动触发
        return self.title  # 返回值

4.1 增查改删

# 增加
res = models.Books.objects.create(title='人性的弱点',price=687.90)
print(res.title)   # 人性的弱点 
'''create返回值就是当前被创建的数据对象'''

# 查询
res = models.Books.objects.all()
print(res.query) # query查看当前orm内部对应的原生sql语句
res = models.Books
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值