oracle中“select 1 from table”是啥意思?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle中“select 1 from table”是啥意思?相关的知识,希望对你有一定的参考价值。

select 1 from table 与Select * from table在用法上大同小异,具体不同分析见下文:

1、select 1 from mytable;与select anycol(目的表集合中的任意一行) from mytable;与select * from mytable 作用上来说是没有差别的,都是查看是否有记录,一般是作条件用的。select 1 from 中的1是一常量,查到的所有行的值都是它,但从效率上来说,1>anycol>*,因为不用查字典表。

2、查看记录条数可以用select sum(1) from mytable;等价于select sum(*) from mytable;

3、实际项目SQL:

select c_insrnc_cde, c_nme_cn
from t_prd_ins a
where a.c_prod_no = '01'
and not exists
(select 1
from (select d.c_insrnc_cde, a.c_nme_cn
from t_prd_ins a,
tb_bas_ply_policy_rdr c,
tb_bas_ply_policy_rdr_list d
where a.c_insrnc_cde = d.c_insrnc_cde
and d.c_policy_id = c.c_policy_id
and d.c_seq_no = c.c_seq_no
and a.c_kind_no = '01'
and c.c_dpt_cde = '101' ----机构树中取出机构
and c.c_prod_no = '01'
and c.t_effc_tm <= TO_DATE('2007-9-5', 'YYYY-MM-DD')
and c.t_expd_tm >= TO_DATE('2007-9-5', 'YYYY-MM-DD')
and c.c_work_mode = '00501'
and c.c_reach_area = '00701'
) t
where t.c_insrnc_cde = a.c_insrnc_cde);

测试场景:
table表是一个数据表,假设表的行数为10行。

1:select 1 from table 增加临时列,每行的列值是写在select后的数,这条sql语句中是1

2:select count(1) from table 不管count(a)的a值如何变化,得出的值总是table表的行数

3:select sum(1) from table 计算临时列的和

在SQL SERVER中用 1 测试了一下,发现结果如下:

1:测试结果,得出一个行数和table表行数一样的临时列(暂且这么叫,我也不知道该叫什么),每行的列值是1;

2:得出一个数,该数是table表的行数;

3:得出一个数,该数是table表的行数;

然后我又用“2”测试,结果如下:

1:得出一个行数和table表行数一样的临时列,每行的列值是2;

2:得出一个数,该数是table表的行数;

3:得出一个数,该数是table表的行数×2的数

然后我又用更大的数测试:

1:得出一个行数和table表行数一样的临时列,每行的列值是我写在select后的数;

2:还是得出一个数,该数是table表的行数;

3:得出一个数,该数是table表的行数×写在select后的数

综上所述:第一种的写法是增加临时列,每行的列值是写在select后的数;第二种是不管count(a)的a值如何变化,得出的值总是table表的行数;第三种是计算临时列的和。

语句if not exists(select 1 from deleted d join inserted i on d.ID=i.ID
and d.col1=1 and i.col1=2)

if not exists 如果不存在
(..)这里该是验证更新,更新前的id等于更新后的id,并且更新前col的值是1,更新后的值是2
参考技术A oracle的全局临时表是有作用域的问题的,你需要这样做
create
global
temporary
table
temp1(goodsid
number)
on
commit
preserve
rows
;
insert
into
temp1
select
。。。
commit
;
这样可以保留下来数据,但是如果session关闭掉后数据也会丢失掉。

存储过程中的mysql动态查询

【中文标题】存储过程中的mysql动态查询【英文标题】:mysql dynamic query in stored procedure 【发布时间】:2014-06-04 10:06:09 【问题描述】:

我正在存储过程中创建一个动态查询。我的存储过程如下:

CREATE PROCEDURE `test1`(IN tab_name VARCHAR(40),IN w_team VARCHAR(40))
BEGIN
SET @t1 =CONCAT("SELECT * FROM ",tab_name," where team=",w_team);
 PREPARE stmt3 FROM @t1;
 EXECUTE stmt3;
 DEALLOCATE PREPARE stmt3;
END

当我尝试通过以下调用运行它时:

call test1 ('Test','SPA');

我收到以下错误消息:

错误代码:1054。“where 子句”中的未知列“SPA”

我在没有 where 条件的情况下进行了测试,它工作正常,但是在 where 条件下它不起作用,我尝试使用带有变量名的 @,但它仍然不起作用。

感谢您的帮助。

【问题讨论】:

【参考方案1】:

错误代码:1054。“where 子句”中的未知列“SPA”

当您没有将输入字符串括在引号中时,会发生这种情况,并且 SQL 引擎会尝试将其识别为正在查询的表中的列。但它失败了,因为它找不到它。

但是当它找到这样的列时会发生什么? 当它在列值上找到一些匹配项时,它会获取结果。 显然,这不是人们所期望的。

如何克服这个问题?使用带有动态输入值的预处理语句。

您也可以在存储过程中使用像? 这样的占位符来处理动态输入值,以便与Prepared Statements 一起使用。当分配给 SQL 表达式或在 SQL 表达式中进行比较时,引擎将处理转义字符和其他字符串值。

您只需根据需要将过程输入重新分配给一个或多个会话变量。

程序示例

CREATE PROCEDURE `test1`( IN tab_name VARCHAR(40), IN w_team VARCHAR(40) )
BEGIN
  SET @t1 = CONCAT( 'SELECT * FROM ', tab_name, ' where team = ?' ); -- <-- placeholder
  SET @w_team := w_team;

  PREPARE stmt3 FROM @t1;
  EXECUTE stmt3 USING @w_team; -- <-- input for placeholder
  DEALLOCATE PREPARE stmt3;
END;

【讨论】:

【参考方案2】:

您错过了在WHERE 子句中包含参数w_team

试试这样:

SET @t1 =CONCAT("SELECT * FROM ",tab_name," where team='",w_team,"'");

解释

您的代码中的查询类似于:

SELECT * FROM Test where team=SPA

它将尝试查找不可用的列SPA,因此会出现错误。

我们将其更改为:

SELECT * FROM Test where team='SPA'

【讨论】:

SET @t1 =CONCAT("SELECT col1 into '@'var1 FROM ",tab_name," where team='",w_team,"'"); var1 总是为空,这是为什么呢? @Shann:你想做什么? 我正在尝试将 col1 存储到 var1 中,我将 @ 放在 '' 中,因为我在堆栈上有错误。 尝试删除@周围的单引号。 我试过了,但我得到了空值,因为堆栈错误我添加了单引号。【参考方案3】:

试试这个..

CREATE PROCEDURE `test1`(IN tab_name VARCHAR(40),IN w_team VARCHAR(40))
BEGIN
SET @t1 =CONCAT("SELECT * FROM ",tab_name," where team='",w_team,"'");
 PREPARE stmt3 FROM @t1;
 EXECUTE stmt3;
 DEALLOCATE PREPARE stmt3;
END

w_team 变量周围缺少引号。

您应该打印动态构建的语句,这样您就可以复制打印的语句并尝试这样您就可以轻松找到此类问题。

select @t1 将打印动态构建的语句..

【讨论】:

【参考方案4】:

您可以使用 CONCAT() MySQL 函数添加动态字段和条件。我检查了它工作正常。

 DELIMITER $$
 /*define procedure name*/
 CREATE PROCEDURE getSearchData()
 BEGIN
 
 DECLARE conditions varchar(1000);
 DECLARE selectField varchar(1000);
 DECLARE SQL_QUERY  varchar(1000);   

 /*define  default select and condition*/
 SET @selectField = 'status,id';
 set @conditions = ' where return_flight=0'; 

 SET @SQL_QUERY = CONCAT('SELECT ',@selectField, ' FROM flights ',@conditions);   
/* you can add more select fields and conditions according to your requirement */ 

PREPARE stmt1 FROM @SQL_QUERY ;
EXECUTE stmt1;
DEALLOCATE PREPARE stmt1;
END$$
DELIMITER ;

【讨论】:

以上是关于oracle中“select 1 from table”是啥意思?的主要内容,如果未能解决你的问题,请参考以下文章

在PostgreSQL中使用oracle_fdw访问Oracle

oracle中DateDiff()的用法

oracle中DDL DML指啥?

oracle中INTERSECT,MINUS用法

oracle中DDL DML指啥?

oracle中ORDER BY