4.2、sqlplus、pl/sql中的sql语句使用
注意:以下带*的语句都已经在SQLPLUS中经过测试。
4.2.1、如何返回系统当前日期、当前连接用户……
* select sysdate from dual;--系统日期
* select to_char(sysdate, 'yyyymmdd hh24:mi:ss') from dual;--格式化后的日期
* select user from dual;--当前用户
4.2.2、如何返回某字符的ASCI码、某asci码对应的字符
* select ascii('N') from dual;--返回字母N的ASCI码
* select chr('78') from dual;--返回数字78对应的字符
4.2.3、使用decode 进行代码转换
select decode(column, 'var_1', 'val_1', 'var_2', 'val_2'…, 'var_n', 'val_n', , 'val_x')from tab;
4.2.4、学会使用其它常用函数trunc、trim、upper、round、replace、lower、lpad/rpad、substr、instr、translate、sys_context…在SQL语句中对值进行理想化处理。
--对日期截取到天
* select to_char(trunc(sysdate),'yyyymmdd hh24:mi:ss') from dual;
--对日期截取到月
* select to_char(trunc(sysdate,'month'),'yyyymmdd hh24:mi:ss') from dual;
--对日期截取到年
* select to_char(trunc(sysdate,'month'),'yyyymmdd hh24:mi:ss') from dual;
--对数字取整到小数点左边第1位
* select trunc(15.19,1) from dual;
--对数字取整到小数点右边边第1位
* select trunc(15.19,-1) from dual;
--对日期四舍五入到天
* select to_char(round(sysdate),'yyyymmdd hh24:mi:ss') from dual;
--对数字四舍五入到小数点左边第1位
* select round(15.19,1) from dual;
--对字符串去掉左右空格
* select trim(' a b c ') from dual;
--去掉数字串中的某个数字
* select trim(0 from 00001234000) from dual;
--将字符串中的某个字符串替换为另一个字符串(可空)
* select replace('00001234000','0','') from dual;
--对字符串进行一一对应的翻译
* select translate('FA','ABCDEFG','白黑红蓝黄银灰') from dual;
--将字符传转为大写
* select upper('abc') from dual;
--将字符传转为小写
* select lower('AbC') from dual;
--将字符串用某个字符串(本例为W)左补齐(右补齐为rpad)到指定长度(本例为10)
* select lpad('abc',10,'W') from dual;
--从字符串指定位置(本例为2)截取指定长度(本例为3,缺省为截取到末尾)的子串。
* select substr('abcdef',2,3) from dual;
--获取字符串中子串从指定位置(缺省为1)起第一次出现的位置
* select instr('abcdedef','de',5) from dual;
--获取当前连接的客户端环境信息,如客户端IP地址
* select sys_context('USERENV','IP_ADDRESS') from dual;
4.2.5、在查询语句中使用case实现分支开关语句
* select case when '1'='1' then
'abc'
else
'cba'
end alias_name from dual;
或:
* select case '1' when '1' then
'abc'
else
'cba'
end alias_name from dual;
4.2.6、如何返回表的前N行,第N~M行,按某字段排序后的前N行。
--返回前N行
Select * from tab where rownum<N+1;
--返回第N~M行
Select * from tab where rownum<M+1
Minus
Select * from tab where rownum<N+1;
--返回按某字段排序后的前N行
Select * from (select * from tab order by column desc/asc) where rownum<N+1;
注意,“select * from tab”中的tab可以是一个查询结果集。