关于select 1 ,select count(1),select sum(1)的使用
来源:互联网 发布:python idlt运行不了 编辑:程序博客网 时间:2024/05/22 05:25
关于select 1 ,select count(1),select sum(1)的使用
- 博客分类:
- Oracle
SQL数据结构
看到了很有一些很有意思的例子,拿出来分享一下
所有的一切源于一个实验,在ORA数据库下
结果: title: 1
value: 1
结果: title: 0
value: 0
在表a中多插入几行,比如,又插入3行,值随便取,再使用select 1/0 查询,返回的title还是一样,value多了3行,值还是那样,select 1则值为1,select 0则值为0
---------------------------------结论------------------------------------
所以select n(n为任意常量,浮点数,负数,字符串也可以)只是为了判断select的对象表中是否存在满足条件的记录,存在记录就返回一行。上述select语句还可以加入where子句,比如
满足条件的记录有多少条,结果就返回多少行,行值为所n所对应的常量值;如果没有符合条件的记录,则提示 no rows returned
---------------------------------应用------------------------------------
我所能想到的是字符串的拼接。比如要生成一个序列号,头6位统一的为100000,后两位为A,B字段的值,则可以这样生成,然后将结果写到序列号表中
---------------------------------讨论------------------------------------
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
所有的一切源于一个实验,在ORA数据库下
- create table t (a int ,b int);
- insert into t values(2,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
- select 0 from t;
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子句,比如
- select 1 from t where t.B = 3;
select 1 from t where t.B = 3;
满足条件的记录有多少条,结果就返回多少行,行值为所n所对应的常量值;如果没有符合条件的记录,则提示 no rows returned
---------------------------------应用------------------------------------
我所能想到的是字符串的拼接。比如要生成一个序列号,头6位统一的为100000,后两位为A,B字段的值,则可以这样生成,然后将结果写到序列号表中
- select 100000 || t.A || t.B from t;
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
- 关于select 1 ,select count(1),select sum(1)的使用
- Count (*),Select Count(1),Select Count(column)的区别
- select count(*) 和select count(1)和select count(col)
- select count(*), select count(0), select count(1)
- select count(*) 与 select count(1)区别?
- select count(1) 与select count(*)简析
- 论证select count(*)和select count(1)
- sql select * ,select 1, select count(*) ,select count(1)的区别
- select count(*)和select count(1)的区别(转载)
- select count(*)和select count(1)的区别
- select count(*)和select count(1)的区别
- select count(*)和select count(1)的区别
- select count(*)和select count(1)的区别 .
- select count(*)和select count(1)的区别
- select count(*)和select count(1)的区别
- select count(*)和select count(1)的区别
- select count(*)和select count(1)的区别
- select count(*)和select count(1)的区别
- CentOS下搭建DNS详细版
- DOS下批处理菜单的实现
- 股市的复利模式
- 软件开发流程(转载)
- 黑马程序员 HTML基础
- 关于select 1 ,select count(1),select sum(1)的使用
- 2006年百度之星程序设计大赛初赛题目2:蝈蝈式的记分
- ORACLE ROWNUM ROWid
- TCP/IP的三次握手和四次分手以及超时机制
- Android系列之Intent
- 去除虚拟机Linux的报警声
- 查询rpm的网站
- 寻找二叉树两节点的最近的公共祖先
- linux 中查找文件,并且将目标文件按时间顺序排序