关于select 1 ,select count(1),select sum(1)的使用?

看到了很有一些很有意思的例子,拿出来分享一下
所有的一切源于一个实验,在ORA数据库下
Sql代码   收藏代码
  1. create table t (a int ,b int);  
  2. insert into t values(2,3);  
  3. select 1 from t;  
create table t (a int ,b int); insert into t values(2,3); select 1 from t;

结果:  title: 1
        value: 1

Sql代码   收藏代码
  1. select 0 from t;  

结果:  title: 0
        value: 0

    在表a中多插入几行,比如,又插入3行,值随便取,再使用select 1/0 查询,返回的title还是一样,value多了3行,值还是那样,select 1则值为1,select 0则值为0

---------------------------------结论------------------------------------
    所以select n(n为任意常量,浮点数,负数,字符串也可以)只是为了判断select的对象表中是否存在满足条件的记录,存在记录就返回一行。上述select语句还可以加入where子句,比如
Sql代码   收藏代码
  1. select 1 from t where t.B = 3;  

    满足条件的记录有多少条,结果就返回多少行,行值为所n所对应的常量值;如果没有符合条件的记录,则提示 no rows returned
---------------------------------应用------------------------------------
    我所能想到的是字符串的拼接。比如要生成一个序列号,头6位统一的为100000,后两位为A,B字段的值,则可以这样生成,然后将结果写到序列号表中
Sql代码   收藏代码
  1. select 100000 || t.A || t.B from t;  

---------------------------------讨论------------------------------------
1、select 1 与 select *的区别
    selelct 常量 from ... 对应所有行,返回的永远只有一个值,即常量 。所以正常只会用来判断是否有还是没有(比如exists子句)。而select * from ... 是返回所有行的所有列。
    性能上的差异,关键看你的from和where子句。比如说如果你的where条件中可以通过索引,那显然 select 1 from ... 的性能比 select * from ... 好。
2、select count(1)与select count(*)的区别
   跟表结构有关系:
   如果表中没有主键,那么count(1)比count(*)快
   如果有主键,那么count(主键,联合主键)比count(*)快
   如果表中只有一个字段,count(*)最快
3、select sum(1)的使用
   select count(*)返回所有满足条件的记录数,此时同select sum(1)
   但是sum()可以传任意数字,负数、浮点数都可以,返回的值是传入值n*满足条件记录数m

转载于:https://www.cnblogs.com/memorywang/articles/2015075.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值