`

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

阅读更多
看到了很有一些很有意思的例子,拿出来分享一下
所有的一切源于一个实验,在ORA数据库下
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;

结果:  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;

    满足条件的记录有多少条,结果就返回多少行,行值为所n所对应的常量值;如果没有符合条件的记录,则提示 no rows returned
---------------------------------应用------------------------------------
    我所能想到的是字符串的拼接。比如要生成一个序列号,头6位统一的为100000,后两位为A,B字段的值,则可以这样生成,然后将结果写到序列号表中
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
6
0
分享到:
评论
1 楼 来利强 2011-11-04  

相关推荐

    SQL一条语句统计记录总数及各状态数

    代码如下:SELECT SUM(正确数)+SUM(错误数) AS 总记录数,SUM(正确数),SUM(错误数) FROM ( SELECT COUNT(1) 正确数,0 错误数 FROM TB WHERE STATUS=1 UNION ALL SELECT 0 正确数,COUNT(1) 错误数 FROM TB WHERE ...

    SQLite3 轻量级数据库及SQL语法指导

    求和:select sum(field1) from table1; 平均:select avg(field1) from table1; 最大:select max(field1) from table1; 最小:select min(field1) from table1; 排序:select 字段 from table1 order by 字段(desc...

    SQL语句中SUM与COUNT的区别深入分析

    SUM是对符合条件的记录的数值列求和 COUNT 是对查询中符合条件的结果(或记录)的个数 例如: 表fruit id name price 1 apple 3.00 2 pear 4.00 ... 您可能感兴趣的文章:解析关于SQL语句Count的一点细节

    SQL 2008 常用语句大全

     求和:select sum(field1) as sumvalue from table1  平均:select avg(field1) as avgvalue from table1  最大:select max(field1) as maxvalue from table1  最小:select min(field1) as minvalue from ...

    SQL语句经典大全

    求和:select sum(field1) as sumvalue from table1 平均:select avg(field1) as avgvalue from table1 最大:select max(field1) as maxvalue from table1 最小:select min(field1) as minvalue from table1...

    sql中count或sum为条件的查询示例(sql查询count)

    往往初学者会错误地认为在where 语句里直接使用count()算法,很显然这个想法是错误的,count()方法并不能被用在where子句中,为了解决问题,我们可以在group by子句后面使用HAVING来做条件限制。错误做法:select * ...

    使用SQL语句统计数据时sum和count函数中使用if判断条件的讲解

    sum函数中使用if判断条件:{ sum( IF (order_type = 0, real_price, 0) ) AS '当天支付收入', sum( IF (order_type = 1, real_price, 0) ) AS '当天打赏收入', } count(DISTINCT open_id) AS '付费总人数', count

    SQL SUM() 函数

    SELECT SUM(column_name) FROM table_name; 演示数据库 在本教程中,我们将使用 RUNOOB 样本数据库。 下面是选自 “access_log” 表的数据: mysql> SELECT * FROM access_log; +-----+---------+-------+--------...

    mysql 常用语句+实例

    求和:select sum(field1) as sumvalue from table1 平均:select avg(field1) as avgvalue from table1 最大:select max(field1) as maxvalue from table1 最小:select min(field1) as minvalue from table1 11、...

    T-SQL高级查询

    select count(*), age, sum(age) from student where age is not null group by age with cube; cube要结合group by语句完成分组汇总 Ø 排序函数 排序在很多地方需要用到,需要对查询结果进行排序并且给出...

    50个常用SQL语句,很好

    SELECT SUM(CASE WHEN C# ='001' THEN score ELSE 0 END)/SUM(CASE C# WHEN '001' THEN 1 ELSE 0 END) AS 企业管理平均分 ,100 * SUM(CASE WHEN C# = '001' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C#...

    MYSSQL_MSS_ORACLE经典SQL.pdf

    SELECT SUM(CASE WHEN C# ='001' THEN score ELSE 0 END)/SUM(CASE C# WHEN '001' THEN 1 ELSE 0 END) AS 企业管理平均分 ,100 * SUM(CASE WHEN C# = '001' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C#...

    超实用sql语句

    求和:select sum(field1) as sumvalue from table1 平均:select avg(field1) as avgvalue from table1 最大:select max(field1) as maxvalue from table1 最小:select min(field1) as minvalue from table1 11、...

    sql最全的常用命令语句

    select count(*) from Master.dbo.SysProcesses where dbid=db_id() --前10名其他等待类型 SELECT TOP 10 * from sys.dm_os_wait_stats ORDER BY wait_time_ms DESC SELECT *FROM sys.dm_os_wait_stats ...

    case when和sum case when 写法及拼接字段

    1 case when 写法 2 sum case when 用法 3 select 拼接字段 示例如下: when 2 then 'C' else 'D' end ) as '类型',count(*) as '数量' from table group by orderType

    经典SQL语句大全

    set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere 2、收缩数据库 --重建索引 DBCC REINDEX DBCC INDEXDEFRAG --收缩数据和日志 DBCC SHRINKDB DBCC SHRINKFILE 3、...

    数据库操作语句大全(sql)

    set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere 2、收缩数据库 --重建索引 DBCC REINDEX DBCC INDEXDEFRAG --收缩数据和日志 DBCC SHRINKDB DBCC SHRINKFILE 3、...

    SQL语句大全(经典珍藏版)

    求和:select sum(field1) as sumvalue from table1 平均:select avg(field1) as avgvalue from table1 最大:select max(field1) as maxvalue from table1 最小:select min(field1) as minvalue from table1 11、...

    sql经典语句一部分

    set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere 2、收缩数据库 --重建索引 DBCC REINDEX DBCC INDEXDEFRAG --收缩数据和日志 DBCC SHRINKDB DBCC SHRINKFILE 3、...

    oracle_11gR2_07 数据操作(select,insert,update,delete) 和 常用函数

    oracle_11gR2_07 数据操作(select,insert,update,delete) 和 常用函数(count,max,min,avg,sum,decode,distinct)

Global site tag (gtag.js) - Google Analytics