社区首页 >问答首页 >Django在mysql查询中一直在表名两边加引号,查询就不起作用了

Django在mysql查询中一直在表名两边加引号,查询就不起作用了
EN

Stack Overflow用户
提问于 2020-04-06 05:37:52
回答 1查看 93关注 0票数 0

MySql中的表名是usercreds,django生成的查询不需要在表名两边加上引号。这个模型是从django使用inspectdb命令创建的,我正在尝试以db管理器的身份访问django管理面板。

models.py:

代码语言:javascript
代码运行次数:0
复制
# This is an auto-generated Django model module.
# You'll have to do the following manually to clean this up:
#   * Rearrange models' order
#   * Make sure each model has one field with primary_key=True
#   * Make sure each ForeignKey has `on_delete` set to the desired behavior.
#   * Remove `managed = False` lines if you wish to allow Django to create, modify, and delete the table
# Feel free to rename the models, but don't rename db_table values or field names.
from django.db import models


class Usercreds(models.Model):
    id = models.IntegerField(primary_key=True)
    name = models.CharField(max_length=20, blank=True, null=True)
    password = models.CharField(max_length=20, blank=True, null=True)

    class Meta:
        managed = False
        db_table = 'usercreds'

settings.py:

代码语言:javascript
代码运行次数:0
复制
"""
Django settings for admindb project.

Generated by 'django-admin startproject' using Django 2.2.11.

For more information on this file, see
https://docs.djangoproject.com/en/2.2/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/2.2/ref/settings/
"""

import os

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))


# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.2/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '(4n(txlca35l2nk$(#@^p9iin_a5m#&lvu7w=!-8tbb^7e0+33'

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

ALLOWED_HOSTS = []


# Application definition

INSTALLED_APPS = [
    'dbmanagepsql',
    'dbmanagemysql',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

ROOT_URLCONF = 'admindb.urls'

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]

WSGI_APPLICATION = 'admindb.wsgi.application'


# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'testdb',
        'USER': 'postgres',
        'PASSWORD': 'wtfigo!!',
        'HOST': 'localhost',
        'PORT': '5432',
    },
    'mysql': {
        'ENGINE': 'django.db.backends.mysql',
        'OPTIONS': {
            'init_command': 'SET default_storage_engine=INNODB',
            'database': 'testdb',
            'user' : 'root',
            'password' : 'Ftpol018@',
        },
    }
}

# Password validation
# https://docs.djangoproject.com/en/2.2/ref/settings/#auth-password-validators

AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]


# Internationalization
# https://docs.djangoproject.com/en/2.2/topics/i18n/

LANGUAGE_CODE = 'en-us'

TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.2/howto/static-files/

STATIC_URL = '/static/'

我得到的错误是:

代码语言:javascript
代码运行次数:0
复制
ProgrammingError at /admin/dbmanagemysql/usercreds/
relation "usercreds" does not exist
LINE 1: SELECT COUNT(*) AS "__count" FROM "usercreds"

django回溯:

代码语言:javascript
代码运行次数:0
复制
Environment:


Request Method: GET
Request URL: http://localhost:8000/admin/dbmanagemysql/usercreds/

Django Version: 2.2.11
Python Version: 3.6.9
Installed Applications:
['dbmanagepsql',
 'dbmanagemysql',
 'django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles']
Installed Middleware:
['django.middleware.security.SecurityMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware']



Traceback:

File "/home/alex/.local/lib/python3.6/site-packages/django/db/backends/utils.py" in _execute
  84.                 return self.cursor.execute(sql, params)

The above exception (relation "usercreds" does not exist
LINE 1: SELECT COUNT(*) AS "__count" FROM "usercreds"
                                          ^
) was the direct cause of the following exception:

File "/home/alex/.local/lib/python3.6/site-packages/django/core/handlers/exception.py" in inner
  34.             response = get_response(request)

File "/home/alex/.local/lib/python3.6/site-packages/django/core/handlers/base.py" in _get_response
  115.                 response = self.process_exception_by_middleware(e, request)

File "/home/alex/.local/lib/python3.6/site-packages/django/core/handlers/base.py" in _get_response
  113.                 response = wrapped_callback(request, *callback_args, **callback_kwargs)

File "/home/alex/.local/lib/python3.6/site-packages/django/contrib/admin/options.py" in wrapper
  606.                 return self.admin_site.admin_view(view)(*args, **kwargs)

File "/home/alex/.local/lib/python3.6/site-packages/django/utils/decorators.py" in _wrapped_view
  142.                     response = view_func(request, *args, **kwargs)

File "/home/alex/.local/lib/python3.6/site-packages/django/views/decorators/cache.py" in _wrapped_view_func
  44.         response = view_func(request, *args, **kwargs)

File "/home/alex/.local/lib/python3.6/site-packages/django/contrib/admin/sites.py" in inner
  223.             return view(request, *args, **kwargs)

File "/home/alex/.local/lib/python3.6/site-packages/django/utils/decorators.py" in _wrapper
  45.         return bound_method(*args, **kwargs)

File "/home/alex/.local/lib/python3.6/site-packages/django/utils/decorators.py" in _wrapped_view
  142.                     response = view_func(request, *args, **kwargs)

File "/home/alex/.local/lib/python3.6/site-packages/django/contrib/admin/options.py" in changelist_view
  1685.             cl = self.get_changelist_instance(request)

File "/home/alex/.local/lib/python3.6/site-packages/django/contrib/admin/options.py" in get_changelist_instance
  744.             sortable_by,

File "/home/alex/.local/lib/python3.6/site-packages/django/contrib/admin/views/main.py" in __init__
  82.         self.get_results(request)

File "/home/alex/.local/lib/python3.6/site-packages/django/contrib/admin/views/main.py" in get_results
  210.         result_count = paginator.count

File "/home/alex/.local/lib/python3.6/site-packages/django/utils/functional.py" in __get__
  80.         res = instance.__dict__[self.name] = self.func(instance)

File "/home/alex/.local/lib/python3.6/site-packages/django/core/paginator.py" in count
  91.             return c()

File "/home/alex/.local/lib/python3.6/site-packages/django/db/models/query.py" in count
  392.         return self.query.get_count(using=self.db)

File "/home/alex/.local/lib/python3.6/site-packages/django/db/models/sql/query.py" in get_count
  504.         number = obj.get_aggregation(using, ['__count'])['__count']

File "/home/alex/.local/lib/python3.6/site-packages/django/db/models/sql/query.py" in get_aggregation
  489.         result = compiler.execute_sql(SINGLE)

File "/home/alex/.local/lib/python3.6/site-packages/django/db/models/sql/compiler.py" in execute_sql
  1140.             cursor.execute(sql, params)

File "/home/alex/.local/lib/python3.6/site-packages/django/db/backends/utils.py" in execute
  99.             return super().execute(sql, params)

File "/home/alex/.local/lib/python3.6/site-packages/django/db/backends/utils.py" in execute
  67.         return self._execute_with_wrappers(sql, params, many=False, executor=self._execute)

File "/home/alex/.local/lib/python3.6/site-packages/django/db/backends/utils.py" in _execute_with_wrappers
  76.         return executor(sql, params, many, context)

File "/home/alex/.local/lib/python3.6/site-packages/django/db/backends/utils.py" in _execute
  84.                 return self.cursor.execute(sql, params)

File "/home/alex/.local/lib/python3.6/site-packages/django/db/utils.py" in __exit__
  89.                 raise dj_exc_value.with_traceback(traceback) from exc_value

File "/home/alex/.local/lib/python3.6/site-packages/django/db/backends/utils.py" in _execute
  84.                 return self.cursor.execute(sql, params)

Exception Type: ProgrammingError at /admin/dbmanagemysql/usercreds/
Exception Value: relation "usercreds" does not exist
LINE 1: SELECT COUNT(*) AS "__count" FROM "usercreds"
                                          ^

如果有某种方法可以删除引号或不使用引号,那么生成带有引号的查询就可以解决问题。我尝试在models.py中重命名表名,但似乎都不起作用。如果你们熟悉这一点,或者想要使用django管理面板作为数据库管理器ui来对任何数据库执行CRUD操作,请帮助我。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-06 05:54:50

问题不是Django在您的表名两边加了引号,而是您为表查询了错误的数据库。在本例中,它查询postgres数据库,因为这是您设置为default的数据库别名,这是当您没有指定要使用的任何其他特定数据库时Django使用的数据库别名。

代码语言:javascript
代码运行次数:0
复制
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'testdb',
        'USER': 'postgres',
        'PASSWORD': 'wtfigo!!',
        'HOST': 'localhost',
        'PORT': '5432',
    },
    'mysql': {
        'ENGINE': 'django.db.backends.mysql',
        'OPTIONS': {
            'init_command': 'SET default_storage_engine=INNODB',
            'database': 'testdb',
            'user' : 'root',
            'password' : 'Ftpol018@',
        },
    }
}

为了演示这一点,您可以使用.using('db_alias')选择要使用的正确数据库

代码语言:javascript
代码运行次数:0
复制
all_usercreds = Usercreds.objects.using('mysql').all()

如果您不想在每次引用该模型时都调用.using,则可以定义一个自定义数据库路由器并在settings.DATABASE_ROUTERS中注册它,如下所示:my_app.db_routers.py

代码语言:javascript
代码运行次数:0
复制
from my_app.models import Usercreds
class CustomDatabaseRouter(object):
    def db_for_read(self, model, **hints):        
        if model == Usercreds:
            return 'mysql'
        return None

    def db_for_write(self, model, **hints):
        if model == Usercreds:
            return 'mysql'
        return None

app/settings.py

代码语言:javascript
代码运行次数:0
复制
DATABASE_ROUTERS = ('my_app.db_routers.CustomDatabaseRouter',)

来源:https://docs.djangoproject.com/en/3.0/topics/db/multi-db/

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61053541

复制
相关文章
Java 类和对象,如何定义Java中的类,如何使用Java中的对象,变量
6.类与对象方法,属性的联系和区别:类是一个抽象的概念,仅仅是模板,比如:“手机”对象是一个你能够看得到,摸得着的具体实体
用户7886150
2021/01/31
6.9K0
对象的表示方法
开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第13天,点击查看活动详情
默默的成长
2022/12/10
5310
Java面向对象——类及类的成员
本讲主要初步了解面向对象,介绍了类的组成部分,并且通过Person类来讲解了类的属性和方法,因为Java是面向对象开发的,所以在项目中会创建很多类和对象,所以这一讲是十分重要的。我们也认识了方法的定义和调用,后续也会写很多方法进行实战。
小明爱吃火锅
2023/09/28
2820
java的类和对象(一)
Java是一种面向对象编程语言,类和对象是Java中最基本的概念之一。类定义了一种数据类型,它包含了数据和方法,而对象是类的一个实例。本文将介绍Java中类和对象的概念、创建对象的方法、成员变量和成员方法、访问修饰符、构造函数、静态变量和方法、继承和多态等内容。
堕落飞鸟
2023/04/02
3400
java的类和对象(二)
静态变量和静态方法是属于类的,而不是属于对象的。静态变量在类加载时就已经存在,无需创建对象即可使用;静态方法可以直接通过类名调用,无需创建对象。
堕落飞鸟
2023/04/02
3760
Java 的对象和类 原
Java 是一种面向对象的语言。作为一个面向的语言,Java 具有面向对象的特性,Java 能够支持下面的一些基本概念 −
HoneyMoose
2019/01/30
5470
Java 的对象和类
                                                                            原
java的类和对象(三)
多态是Java中另一个重要的面向对象编程概念。多态的意思是同一个方法调用,由于对象不同可能会产生不同的行为。
堕落飞鸟
2023/04/02
3700
由MySQL复制延迟说起
杨奇龙,网名“北在南方”,7年DBA老兵,目前任职于杭州有赞科技DBA,主要负责数据库架构设计和运维平台开发工作,擅长数据库性能调优、故障诊断。
田帅萌
2019/05/13
1.1K0
由MySQL复制延迟说起
由MySQL复制延迟说起
相信 slave 延迟是MySQL dba 遇到的一个老生长谈的问题了。我们先来分析一下slave延迟带来的风险
用户1278550
2019/04/25
1.3K0
由MySQL复制延迟说起
Java:对象and类?
Java的对象和类,我们可以简单理解为对象是由属性和行为构成的,既然有属性也就会产生数据。这里我们可以将类理解为用于描述一类对象的行为和状态,即把类可以看做一个模板,这个模板将会包括一些关于对象的行为或状态。
小Bob来啦
2021/10/21
1K0
Java:对象and类?
类对象 与 类的对象
一、类对象 1.创建类对象 Class<?> class1 = Class.forName("d01_student.Student"); 2.类对象方法(反射) 2.1构造方法 Class<?> c
2020/10/23
1.1K0
Java——类和对象的使用练习
  好了,今天的练习就分享到这里,希望大家多多关注,多多练习。谢谢大家的欣赏与关注!!
RAIN7
2021/08/11
4700
Java---对象与类的封装
一、类和对象: package cn.hncu.Myclasslearn; /** * * @author hncu_chx * * Mylove amin */ /**类是一种数据类型,声明一个类就是定义了一个数据类型。 类的实例(instance)是类的取值,对象就是类的变量,一个对象能引用一个实例, 就像一个int变量i能够保存int类型的一个常数。 声明对象: 类 对象 MyDate d1;//声明d1是MyDate类的一个对象 **/ publ
谙忆
2021/01/20
5130
Java---对象与类的封装
Java类、对象和方法的应用
相信大家在接触Java之后,一定不会对类和方法陌生吧?很多人把基础学完,简单的编程对于自己来说轻轻松松,但是复(zhuang)杂(bi)一点的代码对于刚学会的人来说,还是比较费时间的!下面我们就来看看把!!!
Bess Croft
2020/04/03
7270
java的类和对象(上.1)
我们都知道java是一门面向对象的一门语言,在这里就要说下面向过程了,它们有什么不同呢?
一个风轻云淡
2022/11/13
4940
java的类和对象(上.1)
Python 面向对象-如何查看类的父类,外部如何获取类的名字
B.__base__.__name__ 可以获取到父类的名字。 没有的话就是 object,object 就是一切对象的父类。
小蓝枣
2020/09/23
2.9K0
JAVA编程中的类和对象
1:初学JAVA,都知道JAVA是面向对象的编程。笔者这节开始说说类和对象。(实例仅供参考,如若复制粘贴记得修改包名和类名,避免出错) 学习JAVA的快捷键,Alt+/代码补全功能,其实此快捷键启动了
别先生
2017/12/29
9810
Java-类与对象的关系
类是一种抽象的数据类型,它是对某一类事物整体描述/定义,但是并不能代表某一个具体的事物. 动物、植物、手机、电脑...... Person类、Pet类、Car类等,这些类都是用来描述/定义某一类具体的事物应该具备的特点和行为 ​ 对象是抽象概念的具体实例 张三就是人的一个具体实例,张三家里的旺财就是狗的一个具体实例。 能够体现出特点,展现出功能的是具体的实例,而不是一个抽象的概念. 重要:一个类即使什么也不写,也是一个方法 示例代码: Student类【方法】 //学生类 public class S
白衣少年
2022/12/26
3140
Java-类与对象的关系
JAVA面向对象-类和对象
面向对象是java语言编程的特征,也是它好用的关键。学习起来并不困难,只是需要理解 学习之前,我们需要了解自己能否进行现在的学习 先阅读必备技能 :必备基础
玖柒的小窝
2021/12/17
9980
Java对象和类
Java作为一种面向对象语言,支持以下基本概念 多态,继承,封装,抽象,类,对象,实例,方法,重载。 本节我们重点研究对象和类的概念。 对象,对象是类的一个实力,有状态和行为,类如,一条狗是一个对象,它的状态有颜色,名字,品种;行为有:摇尾巴,叫,吃等 类,类是一个模板,它描述一类对象的行为和状态。 Java中的对象, 现在让我深入了解什么是对象,看看周围真实的世界,回发现身边有很多对象,车,狗,人等等。所有这些对象都有自己的状态和行为。 拿一条狗来举例,它的状态有名字,品种,颜色,行为有叫,摇尾巴和跑。
landv
2018/05/24
8820

相似问题

如何获得由PlaceId表示的道路形状

12

延迟跳跃

244

强制加载由Java对象表示的图像数据

24

使用java反射获取由代理表示的对象

31

生成的java类不表示更改

14
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档