1. PL/SQL 转义

  • select order#, ………  from ****
  • select col1 from A where col2 like '%\_keywors%' escape '\';
  • update A set url = 'homepage.aspx?code=32' ||  '&' || 'active=0'     --&

update A set url = 'homepage.aspx?code=32' ||  chr(38) || 'active=0'     --&

2. EXTRACT

日付の要素 element 引数
YEAR
MONTH
DAY
HOUR
MINUTE
SECOND
タイムゾーン
情報あり
TIMEZONE_HOUR
TIMEZONE_MINUTE
タイムゾーン名称 TIMEZONE_REGION
タイムゾーン略称 TIMEZONE_ABBR

SELECT EXTRACT(YEAR FROM SYSDATE) FROM DUAL

3.    TRUNC

SELECT SYSDATE S1,                    
     TRUNC(SYSDATE) S2,                 --返回当前日期,无时分秒
     TRUNC(SYSDATE,'YEAR') YEAR,        --返回当前年的1月1日,无时分秒
     TRUNC(SYSDATE,'MONTH') MONTH ,     --返回当前月的1日,无时分秒
     TRUNC(SYSDATE,'DAY') DAY           --返回当前星期的星期天,无时分秒
   FROM DUAL

S1 S2 YEAR MONTH DAY
2015/3/11   11:30 2015/3/11 2015/1/1 2015/3/1 2015/3/8

4.  调用存储过程

DECLARE
  MY_STR_DATE VARCHAR2(100);
BEGIN
  MY_STR_DATE := 'ASDFASDFASDF';
  DBMS_OUTPUT.put_line(MY_STR_DATE);
END;

5.  Exists -- 替换 minus 和 intersect

select *
from (select 1 col1, 'a' col2
from dual
union all
select 2 col1, 'b' col2
from dual) t
where not exists (select 'x'
from (select 1 col1, 'a' col2
from dual
union all
select 2 col1, 'b' col2
from dual) w
where t.col1 = w.col1
and t.col2 = w.col2)

另外: 如果select的内容都出自一个表的时候,比如上面的t和w有不同的列,而最终结果只选择t表中的列,最好用Exists

6. 全角/半角转换(link)

SELECT
TO_MULTI_BYTE(SYS.UTL_I18N.TRANSLITERATE('アAあ11','hwkatakana_fwkatakana')) as full_,
TO_single_BYTE(SYS.UTL_I18N.TRANSLITERATE('アAあ11','kana_hwkatakana')) as half
FROM DUAL

FULL_  HALF
アAあ11 アAア11

7. 用A表的数据更新B表的数据

CODE NAME
1 xxxx
2 yyyy
3 zzzz
4 mmmm
5 wwwww
6 ttttt
CODE NAME
1 111111
2 222222
3 333333
9 999999

方法1:

update a_code s
set s.name =
(select e.name
from a_data e
where e.code = s.code
and rownum < 2)
where s.code in (select code from a_data);

方法2:

merge into a_code t
using a_data d
on (t.code = d.code) -- 带括号
when matched then
update
set t.name = d.name;
CODE NAME
1 111111
2 222222
3 333333
4 mmmm
5 wwwww
6 ttttt

8. (NOT)  IN / EXISTS

select code from t where code IN (1,2)  => select code from t where code = 1 or code = 2

select code from t where code NOT IN (1,2,null)  => select code from t where code <> 1 and code <> 2 and code <> null

code <> null 的值为unknown,所以NOT IN (1,2,null)的返回的结果集为空,如果用not in就需要把含有null的过滤掉

或则改用Exists

select code from t where NOT EXISTS (select 1 from x where t.code = x.code)

9. coalesce / NVL

coalesce (val1, val2, val3) :

coalesce 可以有多个参数,当val1的值为null的时候,返回val2,如果val2也为空,则返回val3,最后一个参数不能为null即可;如果最后一个参数为null,则返回错误。

NVL(val1, val2) :

NVL只有2个参数,当val1为null的时候,直接返回val2,即使val2为null也不出错;如果val1和val2的数据类型不同,oracle会进行隐式转换,如果转换失败,则返回ERROR;

NVL会同时计算val1和val2的值,对于coalesce只是在val1为null的时候,才会去计算val2的值

另:NVL2(val1, 'completed', 'n/a')

当val1的值为null的时候,返回'n/a',否则返回'completed'

10. 游标更新  where current of 

 cursor c_f is
select a,b from f where length(b) = 5 for update; open c_f;
loop
fetch c_f into v_a, v_b;
exit when c_f%notfound;
update f set a=v_a*v_a where current of c_f;
end loop;

11. Join 写法

select id_num, txt_num, id_lang, txt_lang, txt_trans
from numbers_en
join translations using (id_num)
left join lang using (id_lang);

join translations using id_num 等同于 join translations on numbers_en.id_num = translation.id_num

12. Function VS Procedure: from LINK

13.  赋权限

GRANT SELECT, UPDATE ON "schema1"."table1" TO "schema2" ;

14.  Pipelined Table Functions: LINK

Data is said to be pipelined if it is consumed by a consumer (transformation) as soon as the producer (transformation) produces it, without being staged in tables or a cache before being input to the next transformation.

Pipelining enables a table function to return rows faster and can reduce the memory required to cache a table function's results.

create function
gen_numbers(n in number default null)
return array
PIPELINED
as
begin
for i in 1 .. nvl(n,999999999)
loop
pipe row(i);
end loop;
return;
end;
/
-----------------------------------------------------------
/*
select * from TABLE(gen_numbers(3)); COLUMN_VALUE
------------
1
2
3 OR select *
from (
select *
from (select * from table(gen_numbers(49)))
order by dbms_random.random
)
where rownum <= 6
/ COLUMN_VALUE
------------
47
42
40
15
48
23
*/

15. Foreign Key: On delete -> No Action / Cascade / Set null

No Action: prevents deleting a parent when there are children

Cascade: when a referenced parent table row is removed all the child are removed automatically

Set null: set col to null in child when parent table row is removed

16. unicode TO string

'基準日: ' => UNISTR('\57fa\6e96\65e5\003a\3000')

http://unicodelookup.com/   unicode 编码查询

string TO unicode ???

17.  频繁插入删除操作,可能导致高水位线,重新分析下表,可能使对表引用的查询更快一点

analyze table XXX compute statistics 

18.  LEFT JOIN :)

1. select count  from  left join B on (A.id = B.id and B.col = 'xxx')
                where 1 =1

2. select count(*) from  left join B on (A.id = B.id) 
                where 1 =1 AND B.col = 'xxx'

1,2 的结果可能会不同,

19.  running total

Table XXX:

select tag, insdate, amount,
nvl(lag(amount) over(partition by tag order by insdate), 0) lag_total,
nvl(lead(amount) over(partition by tag order by insdate), 0)
from xxx

20. check English/digital characters only

[1]

select 1 from dual where  REGEXP_LIKE('sd巣', '[^ -~]', 'i') union all

select 1 from dual where  REGEXP_LIKE('abc', '[^ -~]', 'i')

[2]

select translate( 'sd巣abcd', chr(0) || 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789.,- ', chr(0) ) from dual

21. NOCOPY

  TYPE connection IS RECORD (
host VARCHAR2(255), -- Host name of SMTP server
port PLS_INTEGER, -- Port number of SMTP server
tx_timeout PLS_INTEGER, -- Transfer time-out (in seconds)
private_tcp_con utl_tcp.connection, -- For internal use only
private_state PLS_INTEGER -- For internal use only
); FUNCTION helo(c IN OUT NOCOPY connection,
domain IN VARCHAR2) RETURN reply;

NOCOPY is a IN OUT COPY Which is used avoid the overhad of copying IN OUT Parameter Values.
If IN OUT parameter returns huge records we can specify the NOCOPY to copy the values.
The PLSQL Engine first makes a copy of the record and then during program executing makes a changes to that copy.

22. bitwise operator:BITAND

oracle中只有BITAND函数;

位或: 
BITOR(x,y) = (x + y) - BITAND(x, y);

异或:
BITXOR(x,y) = BITOR(x,y) - BITAND(x,y) = (x + y) - BITAND(x, y) * 2;

应用:赋权,权限判断的时候可以用这个(判断一个角色是否有多个权限)

23. LISTAGG

select listagg(code, ';') within group (order by code) from table_codes

结果:001; 002; 003

24.

SQL 归来的更多相关文章

  1. struts2+hibernate+spring简单整合且java.sql.SQLException: No suitable driver 问题解决

    最近上j2ee的课,老师要求整合struts2+hibernate+spring,我自己其实早早地有准备弄的,现在都第9个项目了,无奈自己的思路和头绪把自己带坑了,当然也是经验问题,其实只是用myec ...

  2. 最近帮客户实施的基于SQL Server AlwaysOn跨机房切换项目

    最近帮客户实施的基于SQL Server AlwaysOn跨机房切换项目 最近一个来自重庆的客户找到走起君,客户的业务是做移动互联网支付,是微信支付收单渠道合作伙伴,数据库里存储的是支付流水和交易流水 ...

  3. SQL Server 大数据搬迁之文件组备份还原实战

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 解决方案(Solution) 搬迁步骤(Procedure) 搬迁脚本(SQL Codes) ...

  4. Sql Server系列:分区表操作

    1. 分区表简介 分区表在逻辑上是一个表,而物理上是多个表.从用户角度来看,分区表和普通表是一样的.使用分区表的主要目的是为改善大型表以及具有多个访问模式的表的可伸缩性和可管理性. 分区表是把数据按设 ...

  5. SQL Server中的高可用性(2)----文件与文件组

        在谈到SQL Server的高可用性之前,我们首先要谈一谈单实例的高可用性.在单实例的高可用性中,不可忽略的就是文件和文件组的高可用性.SQL Server允许在某些文件损坏或离线的情况下,允 ...

  6. EntityFramework Core Raw SQL

    前言 本节我们来讲讲EF Core中的原始查询,目前在项目中对于简单的查询直接通过EF就可以解决,但是涉及到多表查询时为了一步到位就采用了原始查询的方式进行.下面我们一起来看看. EntityFram ...

  7. 从0开始搭建SQL Server AlwaysOn 第一篇(配置域控)

    从0开始搭建SQL Server AlwaysOn 第一篇(配置域控) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www.cnb ...

  8. 从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群)

    从0开始搭建SQL Server AlwaysOn 第二篇(配置故障转移集群) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://www ...

  9. 从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn)

    从0开始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn) 第一篇http://www.cnblogs.com/lyhabc/p/4678330.html第二篇http://w ...

随机推荐

  1. ASP.NET MVC 5 03 - 安装MVC5并创建第一个应用程序

    不知不觉 又逢年底, 穷的钞票 所剩无几. 朋友圈里 各种装逼, 抹抹眼泪 MVC 继续走起.. 本系列纯属学习笔记,如果哪里有错误或遗漏的地方,希望大家高调指出,当然,我肯定不会低调改正的.(开个小 ...

  2. yum安装php,php-fpm

    1.检查当前安装的PHP包 yum list installed | grep php 如果有安装的PHP包,先删除他们 yum remove php.x86_64 php-cli.x86_64 ph ...

  3. 0035 Java学习笔记-注解

    什么是注解 注解可以看作类的第6大要素(成员变量.构造器.方法.代码块.内部类) 注解有点像修饰符,可以修饰一些程序要素:类.接口.变量.方法.局部变量等等 注解要和对应的配套工具(APT:Annot ...

  4. RHEL6和RHEL7恢复root用户密码

    一.RHEL6恢复root密码 将系统重启,出现如下界面按上下键选择会停住,并输入e键 选中下图红框选项,再输入e键 再输入1,进入单用户模式 输入b进行启动   修改密码,然后重启 二.RHEL7恢 ...

  5. 【java开发】ubuntu常用命令及环境搭建

    学习第一天,今天内容相对简单,主要就是ubuntu一些常用命令及常规操作,后续涉及到环境的搭建,也会在本文再更. ubuntu环境搭建 第一种 也是最简单最方便的 通过vm虚拟机软件,下载iso镜像进 ...

  6. [django]django 在apache2上部署静态文件如何加载

    首先找到apache2的conf文件下的httpd.conf,添加如下信息: Alias /static/ E:/wamp/Apache24/www/static/ <Directory E:/ ...

  7. HDOJ 2111. Saving HDU 贪心 结构体排序

    Saving HDU Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  8. [LeetCode] Contains Duplicate III 包含重复值之三

    Given an array of integers, find out whether there are two distinct indices i and j in the array suc ...

  9. [LeetCode] Sqrt(x) 求平方根

    Implement int sqrt(int x). Compute and return the square root of x. 这道题要求我们求平方根,我们能想到的方法就是算一个候选值的平方, ...

  10. 如何在一台新电脑上配置JAVA开发环境

    对于JAVA新手来说,刚开始要学JAVA,而自己的电脑上毫无与JAVA开发有关的环境,应该如何进行配置呢? (安卓新手也需要JAVA开发环境) 第一步,下载.安装java JRE JRE (Java ...