plsql 学习笔记
来源:互联网 发布:故宫纪录片知乎 编辑:程序博客网 时间:2024/04/30 07:22
1.distinct是所取字段全相同才算相同2.trunc()函数:一、Oracle中的Round和Trunc:如同对数字进行四舍五入和按位截取一样,Oracle对时间日期也提供了这两种功能。但比起对数字进行四舍五入和截取比较复杂:这是因为时间日期是有格式的。下面看看这两个函数的定义和用途:ROUND(date [, format])TRUNC(date [, format])Round函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,Round会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分。二、Round和Trunc函数示例:SQL > select to_char(sysdate, ' yyyy-mm-dd hh24:mi:ss ' ) now_date, 2 to_char( Round (sysdate), ' yyyy-mm-dd hh24:mi:ss ' ) round_date, 3 to_char(Trunc(sysdate), ' yyyy-mm-dd hh24:mi:ss ' ) trunc_date 4 from dual;NOW_DATE ROUND_DATE TRUNC_DATE-- ------------------------------------ -------------------------------------- ----------------------2008 - 06 - 30 14 : 52 : 13 2008 - 07 - 01 00 : 00 : 00 2008 - 06 - 30 00 : 00 : 00这是一个典型的例子,由于我们没有指定round和trunc函数的格式,所以Oracle默认采用了按日期时间的格式,该例子中当前的时间是下午 14:52分,已经超过了12:00 AM这个中界线,所以Round返回07-01日而非06-30日。而Trunc不管三七二十一直接截取前面日期部分返回。另外一个值得注意的地方是这两个函数返回的时分秒都是00:00:00,即一天的开始时间(对于12小时制的返回的是12:00:00 AM)。三、指定格式的Round和Trunc函数示例:如果我们对Round函数和Trunc函数指定了格式,事情就变得有点复杂了,不过核心思想还是不变:Round是四舍五入,Trunc是截取。举个例子来说,假如我们以年为格式,则现在Oracle的判断是基于年来判断,超过一年的一半(即6月30日),Round函数则返回下一年了,Trunc函数依然返回当前年。SQL > select sysdate "Now date", 2 Round (sysdate, ' yyyy ' ) Round_year, 3 Trunc(sysdate, ' yyyy ' ) Trunc_year 4 from dual;Now date ROUND_YEAR TRUNC_YEAR-- -------- ---------- ----------30 - 6月 - 08 01 - 1月 - 08 01 - 1月 - 08关于这两个函数可用的格式非常多,但日常应用中用得比较多的基本上就这几个,以Round函数为例:select Round (sysdate, ' Q ' ) Rnd_Q, Round (sysdate, ' Month ' ) Rnd_Month, Round (sysdate, ' WW ' ) Rnd_Week, Round (sysdate, ' W ' ) Rnd_Week_again, Round (sysdate, ' DDD ' ) Rnd_day, Round (sysdate, ' DD ' ) Rnd_day_again, Round (sysdate, ' DAY ' ) Rnd_day_of_week, Round (sysdate, ' D ' ) Rnd_day_of_week_again, Round (sysdate, ' HH12 ' ) Rnd_hour_12, Round (sysdate, ' HH24 ' ) Rnd_hour_24, Round (sysdate, ' MI ' ) Rnd_minute from dual 四、用trunc函数处理日期 日期用例 '2008-11-28 12:59:59'周五 1.没有fmt部分时 语句: SELECT TRUNC(TO_DATE('2008-11-28 12:00:01','YYYY-MM-DD hh24:mi:ss')) FROM DUAL; 结果: 2008-11-28 2.得到最当前日期之前的最近的一个周日的日期 语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'D') FROM DUAL; 结果: 2008-11-23 周日 语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'D')+1 FROM DUAL; 结果: 2008-11-24 周一 3.得到最当前日期的所在月份的第一天 语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'MM') FROM DUAL; 结果: 2008-11-1 语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'MM')-1 FROM DUAL; 结果: 2008-10-31 4.得到最当前日期的所在年份的第一天 语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'Y') FROM DUAL; 结果: 2008-1-1 语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'Y')-1 FROM DUAL; 结果: 2007-12-31
3.oracle中单引号和双引号的用法
在ORACLE中,单引号有两个作用: 1:字符串是由单引号引用 2:转义。 单引号的使用是就近配对,即就近原则。而在单引号充当转义角色时相对不好理解 1.从第二个单引号开始被视为转义符,如果第二个单引号后面还有单引号(哪怕只有一个)。 SQL> select '''' result from dual; RESULT ------ ' 第二个单引号被作为转义符,第三个单引号被转义,可将sql写成这样更好理解: select ' '' ' from dual; output:' // 2.连接符‘||’导致了新一轮的转义: 连接符号‘||’左右的单引号没有任何的关系, 除非‘||’是作为字符串的一部分(这在动态SQL中很常见)。 SQL> select 'name'||'''' result from dual; RESULT ------ name' 理解:||后面的作为一个字符串,即前后是',中间又是一个密集型单引号串'',因此第一个为转义功能. SQL> select 'name''''' result from dual; RESULT ------ name'' 第一个和最后一个单引号作为字符串引用符,中间四个单引号两两转义. // oracle中使用双引号: 1)一般来说,字符串中的双引号仅仅被当作一个普通字符进行处理。 此时,双引号不需要成对出现: SQL> select 'hh24"小时""mi""分"""ss"秒"' results from dual; RESULTS ------------------------- hh24"小时""mi""分"""ss"秒" // 2)当出现在to_char的格式字符串中时,双引号有特殊的作用, 就是将非法的格式符包装起来,避免出现ORA-01821: date format not recognized错误。 也就是说,去掉双引号和其包含的字符后,剩下的应该是一个合法的格式串。 to_char在处理格式字符串时,会忽略双引号: SQL> select to_char(sysdate,'hh24"小时"mi"分"ss"秒"') results from dual; RESULTS -------------- 06小时39分51秒 // 格式串为'hh24"小时"mi"分"ss"秒"'; 去掉双引号部分后,剩下的是'hh24miss',是一个合法的格式串。 不过即使真不知道双引号的这个用法,也可以这样来处理,虽然麻烦一点: select to_char(sysdate, 'hh24') || '小时' || to_char(sysdate, 'mi') || '分' || to_char(sysdate, 'ss') || '秒' AS RESULT from dual; RESULT -------------- 06小时40分18秒
- plsql 学习笔记1
- PLSQL学习笔记
- 学习plsql笔记
- 20120109plsql学习笔记
- plsql 学习笔记
- Oracle plsql学习笔记
- PLSQL学习笔记
- pLsql 学习笔记(-)
- PLSQL学习笔记 wm_concat
- MySQL/PLSQL学习笔记
- 学习Oracle的PLSQL笔记
- PLsql学习笔记(三)
- PLsql学习笔记(四)
- oracle PLSQL学习笔记--类型
- Oracle PLSQL 学习笔记摘要
- plsql编程学习笔记-2
- Oracle PLSQL 学习笔记一
- Oracle PLSQL 学习笔记二
- 第九周-利息计算器
- C#中被委托的方法必须是静态的吗?
- Android SDK编译 ——如何将自己源代码加入android.jar
- JS判断文件上传大小
- UML画图流程
- plsql 学习笔记
- 虾米男的伤感爱情日志推荐:我会忘记你,因为你不属于我
- 判断touch事件点是否在view范围内
- ios集合
- JS弹窗方式:window.open和window.showModalDialog
- 分析Power key的处理流程
- c# winform 子父窗体交互信息
- 从程序员到项目经理(四):外行可以领导内行吗
- mongodb的启动总忘,记一笔!