如何用Mimer Validator检查SQL查询

日期: 2009-04-13 作者:Rudy Limeback翻译:April 来源: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中, 有效,并带有如下注……

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

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)就是一个键,所以用索引查询会比较有效。

翻译

April
April

相关推荐