繁体   English   中英

Substring 来自 Peewee ORM 中的 select

[英]Substring from select in Peewee ORM

我正在将我的程序的代码库从 Peewee v2 更新到 v3。 在代码中,我在 select 语句中执行 substring 语句,该语句在 v2 中始终有效,但现在不再有效。 我有下表

class Project(BaseModel):
project_id = CharField(column_name='projectID', primary_key=True)
name = CharField()
relative_path = CharField()
product_id = ForeignKeyField(column_name='productID', model=Product, field='product_id')

class Meta:
    table_name = 'project'
    indexes = (
        (('name', 'product_id'), True),
    )

我的查询如下:

project_prefix = "INH"

query = internal_projects = Project.select(fn.substring(Project.project_id, len(project_prefix) + 1))\
.where(Project.project_id.startswith(project_prefix))

for q in query:
    print q

这给了我结果:

None
None
None
None
None
None
None

但是,如果我将 fn.substring 排除在查询之外,则结果会很好,例如:

INH00001
INH00002
INH00004
INH00005
INH00006
INH00007
INH00008

我从第一个查询中得到“无”的时间确实与第二个查询的结果数量相匹配,所以它肯定是在选择一些东西。 如何使我的第一个查询再次工作,以便获得预期的结果? 例如:

00001
00002
00004
00005
00006
00007
00008

我猜你访问属性的方式有些时髦。 尝试明确指定别名:

pid = fn.substring(Project.project_id, len(prefix + 1))
query = (Project
         .select(pid.alias('pid'))
         .where(Project.project_id.startswith(prefix)))

for project in query:
    print(project.pid)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM