标签:mis from 员工 返回 引号 标准 双引号 bubuko .com
select 字段名 from 表名;
select salary from s_emp ; (分号代表结束)
select 字段名1 ,字段名2 from 表名;
select ID , FIRST_NAME , SALARY from s_emp ;
标准写法:一个一个列出来
简单写法:*号可以代替所有的字段名(但是这样不知道里面有哪些字段)
select * from 表名;
+ - * /
select salary , salary - 100 from s_emp ;
这样输出后,底层记录的salary是没有变化的
以salary+100算出一年的年薪:
select salary , 12*(salary + 100) from s_emp ;
一个月按照22天算,计算每天的薪水:
select salary , salary / 22 from s_emp ;(除数不会取整,和C不一样)
select 字段名1 ,字段名2 别名 from 表名;
一个字段或者表达式只能有一个别名(也可以没有),别名会自动处理成大写
“别名”会原样显示所取的别名
select salary , salary*13 yearsal from s_emp ;
两个别名会报错:
sql中的字符串使用单引号表达(C里使用双引号表达字符串字面值)
‘ ‘ ‘ ‘ ‘a’ ‘hello world’ 都是字符串
select first_name from s_emp ;也是字符串
字符串拼接符:| |(只针对oracle,其他的可以查一下)
select first_name , last_name from s_emp ;
select first_name || last_name name from s_emp ;
(在C语言中表达‘%’是%%,一个%就是占位符,%d;这里是一样的,用两个 ’ 表示单引号)
select first_name || ‘ ’’ ’ || last_name name from s_emp ;
select first_name || ‘ ‘’ ’ || ‘ ‘’ ’|| last_name name from s_emp ;
或者:
select first_name || ‘ ‘’ ‘’ ’ || last_name name from s_emp ;
空值(NULL值)和任何值做运算结果都是NULL
salary*12+salary*12*(COMMISSION_PCT / 100)
或者:
salary*12*(1+COMMISSION_PCT / 100)
空值处理函数:nvl ( par1 , par2 )
可以处理任何类型的数据,但要求par1和par2的类型保持一致
这个函数,当par1为空时,返回par2的值;par1不为NULL时,返回par1的值
NULL要尽早处理
演示:
select salary , commission_pct , nvl ( salary*12*(1+commission_pct/100) , 0 ) from s_emp ;
是不行的,要尽早处理,不能等着运算完再处理
正确写法:
select salary , commission_pct , salary*12*(1+nvl ( commission_pct , 0 ) /100) from s_emp ;
select id, first_name, manager_id, nvl(manager_id, -1)
dstinct会把所有重复的数据剔除
联合排重(多字段排重,要两个字段都相同的才会剔除)
select salary from s_emp ; 查出所有薪水
select distinct salary from s_emp ; 把重复的剔除
select distinct title , salary from s_emp ;联合排重
标签:mis from 员工 返回 引号 标准 双引号 bubuko .com
原文地址:https://www.cnblogs.com/cjaaron/p/9204737.html