问:假如我的一个表里含有(a,b,c,d)和(a,b)形成组合键。我能在列值中写这个查询吗?例如: select a,c,d from mytable where (a,b) in ((1,2),(1,4),(1,5)) 答:可以。 如果你怀疑有些SQL架构是否有效,就通过Mimer Validator运行一下。在这种情况中,你的查询(你登录校验器中的查询)将得到如下结果: * 在SQL-92中, 无效 * 在SQL-99和SQL_2003中, 有效,并带有如下注……
我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。
我原创,你原创,我们的内容世界才会更加精彩!
【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】
微信公众号
TechTarget
官方微博
TechTarget中国
问:假如我的一个表里含有(a,b,c,d)和(a,b)形成组合键。我能在列值中写这个查询吗?例如:
select a,c,d from mytable where (a,b) in ((1,2),(1,4),(1,5)) |
答:可以。
如果你怀疑有些SQL架构是否有效,就通过Mimer Validator运行一下。在这种情况中,你的查询(你登录校验器中的查询)将得到如下结果:
* 在SQL-92中, 无效
* 在SQL-99和SQL_2003中, 有效,并带有如下注释:
F641, "Row and table constructors"
T051, "Row types"
F561, "Full value expressions"
这时将会用到Core SQL-99以外的如下特征或Core SQL-200x (draft):
F641, "Row and table constructors" T051, "Row types" F561, "Full value expressions" |
也就是说如果你特殊的数据库系统不支持那些选择特征,你仍然会收到错误信息。
也许你想尝试以下查询:
SELECT a,c,d FROM mytable WHERE a = 1 AND b = 2 OR a = 1 AND b = 4 OR a = 1 AND b = 5 |
这个查询运行十分顺利,因为(a,b)就是一个键,所以用索引查询会比较有效。
翻译
相关推荐
-
在SQL中使用SELECT进行算术运算
如何在不使用SQL算术运算符而仅仅使用SELECT的情况下完成数学运算,Oracle数据库专家给出了解答。
-
解决SQL查询性能问题
一旦您优化了数据库索引,配备了最好的硬件和最快的磁盘,您将遇到的瓶颈是SQL Server主机的最大性能。
-
利用内联视图进行数据库表合并
利用SQL Select语句进行数据库表合并的时候,Oracle数据库专家Dan Clamage建议DBA可以使用内联视图来操作。
-
对ID列进行分类整理的SQL查询
在数据库规模较大,重新设计schema已经不太现实的情况下,如何对ID列进行分类整理?Oracle数据库专家Karen Morton给出了具体的SQL查询代码。