Peewee在python控制台中检索数据,但在应用程序中不检索

2024-05-16 13:45:09 发布

您现在位置:Python中文网/ 问答频道 /正文

我用Python中的peewee设计了实体。在开始实现真正的数据库之前,我已经对内存中的数据库进行了一些测试。当我开始实现数据库功能时,我遇到了一个奇怪的问题。我的查询返回空结果,这更取决于我是运行脚本还是使用python控制台。你知道吗

首先,让我来证明逻辑是正确的。当我使用python控制台时,一切正常:

>>> from Entities import *
>>> print (RouterSettings.select().where(RouterSettings.name=='RUT00').get().name)
RUT00

如你所见,一切都是正确的。执行特定查询并返回结果。现在在脚本中也是这样:

from Entities import *
print (RouterSettings.select().where(RouterSettings.name=='RUT00').get().name)

返回异常实例匹配查询不存在

print (RouterSettings.select().where(RouterSettings.name=='RUT00').get().name) File "C:\Users\Kamil\AppData\Local\Programs\Python\Python37-32\lib\site-packages\peewee.py", line 5975, in get (clone.model, sql, params)) Entities.RouterSettingsDoesNotExist: instance matching query does not exist : SQL: SELECT "t1"."id", "t1"."name", "t1"."ip", "t1"."username", "t1"."password", "t1"."model", "t1"."phone_num", "t1"."provider", "t1"."location" FROM "routersettings" AS "t1" WHERE ("t1"."name" = ?) LIMIT ? OFFSET ? Params: ['RUT00', 1, 0]

当我试着调试时,我发现数据库好像没有创建: enter image description here 请注意,在调试变量中,数据库对象为null(None)。 你知道发生了什么事吗?你知道吗

我的实体定义如下:

from peewee import *


class EnumField(IntegerField):

    def __init__(self, *argv):
        super().__init__()
        self.enum = []
        for label in argv:
            self.enum.append(label)

    def db_value(self, value):
        try:
            return self.enum.index(value)
        except ValueError:
            raise EnumField.EnumValueDoesnExistError(
                "Value doesn\'t exist in enum set.\nMaybe you forgot to add "
                "that one: " + value + "?")

    def python_value(self, value):
        try:
            return self.enum[value]
        except IndexError:
            raise EnumField.EnumValueDoesnExistError(
                'No value for given id')

    class EnumValueDoesnExistError(Exception):
        pass

class ModelField(EnumField):

    def __init__(self):
        super().__init__('RUT955_Q', 'RUT955_H', 'GLiNet300M')

class ProviderField(EnumField):

    def __init__(self):
        super().__init__('Orange', 'Play', 'Virgin')


class BaseModel(Model):
    class Meta:
        database = SqliteDatabase('SIMail.db', pragmas={'foreign_keys': 1})


class RouterSettings(BaseModel):

    name = CharField(unique=True)
    ip = CharField(unique=True)
    username = CharField()
    password = CharField()
    model = ModelField()
    phone_num = IntegerField(unique=True)
    provider = ProviderField()
    location = CharField()

Tags: nameself数据库getinitvaluedefenum
1条回答
网友
1楼 · 发布于 2024-05-16 13:45:09

您运行它时可能使用了数据库文件的相对路径,并且根据运行应用程序与控制台时的当前工作目录,它使用的是不同的数据库文件。你知道吗

相关问题 更多 >