当前位置: 首页 > 面试题库 >

在SQLAlchemy中选择NULL值

陶富
2023-03-14
问题内容

这是我的(PostgreSQL)表-

test=> create table people (name varchar primary key,
                            marriage_status varchar) ;

test=> insert into people values ('Ken', 'married');
test=> insert into people values ('May', 'single');
test=> insert into people values ('Joe', NULL);

我想选择所有 知道要结婚的人,即包括那些拥有NULL wedding_status的人。

这并 不能 正常工作-

test=> select * from people where marriage_status != 'married' ; 
 name | marriage_status 
------+-----------------
 May  | single
(1 row)

当然可以-

test=> select * from people where marriage_status != 'married'
       or marriage_status is NULL ; 
 name | marriage_status 
------+-----------------
 May  | single
 Joe  |

问题是我正在使用-从SQLAlchemy访问它

...filter(or_(people.marriage_status!='married',
              people.marriage_status is None))

转换为-

SELECT people.name as name,
       people.marriage_status as marriage_status
FROM people 
WHERE people.marriage_status != %(status_1)s OR False
sqlalchemy.engine.base.Engine.... {'status_1': 'married'}

而且也 没有 工作-

test=> select * from people where marriage_status != 'married'
       or False; 
 name | marriage_status 
------+-----------------
 May  | single
(1 row)

也不-

test=> select * from people where marriage_status != 'married'
       or NULL; 
 name | marriage_status 
------+-----------------
 May  | single
(1 row)

如何通过SQLAlchemy选择NULL值?


问题答案:

(由指示@augurar)):因为
SQLAlchemy的 使用 魔术方法(操作符重载)
创建SQL结构,但它只能处理操作,如!===,但不能与工作is(这是一种非常有效的Python结构)。

因此,要使其与sqlalchemy一起使用,应使用:

...filter(or_(people.marriage_status!='married', people.marriage_status == None))

,基本上取代了is None== None。在这种情况下,您的查询将被正确转换为以下SQL:

SELECT people.name AS people_name, people.marriage_status AS people_marriage_status 
FROM people 
WHERE people.marriage_status IS NULL OR people.marriage_status != ?

请参阅IS NULL中的文档。



 类似资料:
  • 我最近开始学习oracle和SQL。在学习过程中,我遇到了几个问题,我的朋友在一次采访中被问到。 此查询生成Employees表中的所有行。至于我所理解的Oracle在列中搜索数据,那么,NULL,这里是作为列名处理的吗?我说Oracle在列中搜索数据是正确的吗?Oracle怎么会给出这个查询中的所有行呢?在WHERE子句中,条件的左手边不一定是列名吗?它不应该抛出一个错误吗? 不给出选定的行。

  • 问题内容: 我有一个查询,看起来像这样: 这是一个非常基本的查询。除了提取Item的值之外,我还想将其他值添加到混合中,然后将其返回给我。在原始SQL中,我会这样做: 如何通过sqlalchemy手动添加该值? 问题答案: 您需要使用,看起来有点像这样: 注意,该参数无需任何转换即可插入查询;如果您从应用程序外部接受text参数的值,则可能使您暴露于SQL Injection漏洞。如果这是您需要的

  • 问题内容: 如何像在SQL中一样添加过滤器,以从特定列中选择非空值? 如何使用SQLAlchemy过滤器执行相同操作? 问题答案: 会产生一个约束: 在列上下文中,产生子句。如果目标是,则生成一个。 或使用(0.7.9中的新功能): 实施操作员。 通常,当与的值进行比较时,会自动生成,解析为。但是,如果与某些平台上的布尔值进行比较,则可能需要显式使用。 演示:

  • 我有一个工作数据表,可以列出餐馆的对象。我想删除/编辑选定的,但当我选择一个以下异常显示: 这是桌子: 现在所有ID都显示在表中,但在选择时会显示异常。我试着按照这个例子做每件事。但它们甚至没有rowKey属性。 如果相关的话,这是豆子。 } Primefaces:5.3 JSF:2.2

  • 问题内容: 是否可以控制在SQLAlchemy的查询方法中查询哪些列,同时仍返回您正在查询的对象的实例(尽管已部分填充)? 还是SQLAlchemy有必要执行映射到对象? (我确实知道可以查询单个列,但不会将结果映射到对象,而仅映射到命名元组的组件)。 例如,如果User对象具有属性userid,name,password和bio,但是您希望查询仅为其返回的对象填写userid和name: 将打印

  • 问题内容: 我看到一些示例使用带null的select语句。何时使用: 问题答案: Select null通常与EXISTS结合使用。 例如:- 如果选择查询中有记录,则它将“存在”状态设置为true。