一.三种数据库管理系统简介:

Oracle是甲骨文公司的一款关系数据库管理系统。它是一种高效率、可靠性好、适应高吞吐量的数据库。

MySQL 是AB公司开发,目前属于Oracle旗下公司一个关系型数据库管理系统, 它是体积小、速度快、总体拥有成本低,开源,提供的接口支持多种语言连接操作数据库,在WEB应用方面MySQL性能较好。

PostgreSQL是一个关系数据库管理系统。它是是一个开源的,免费的,同时非常强大的关系型数据管理系统。

二:SQL语法书写:

基本的语法SQL通用,大部分PostgreSQL是可以参考Oracle的。

三:日常导数中用到的知识点:

1.关于注释的写法

MySQL注释              /*这里是注释 */

PostgreSQL和Oracle       单行   --这后边就是注释
多行   /*这里是注释这里是第二行注释*/

2.关于分页或者说查几条记录来测试

MySQL数据库分页 

•  select * from 表名 limitstartrow,pagesize 

PostgreSQL数据库分页 

•  select * from 表名 limitpagesize,offset startrow 

Oracle数据库分页 

select* from (select a.*,rownum rc from 表名 whererownum<=endrow) a where a.rc>=startrow

3.关于去重用法或者说业务需求

ROWNUMBER() OVER( PARTITION BY COL1 ORDER BY COL2)用法:

表示根据COL1分组,在分组内部根据 COL2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的).

4.使用正则表达式:对30*40*50取成 30 40 50各成一列(适用于多位数)

regexp_substr(w.size_s, '[^*]+', 1) ,
regexp_substr(w.size_s, '[^*]+', 1,2) ,
regexp_substr(w.size_s, '[^*]+', 1,3) ,
5.关于时间的写法
PostgreSQL和Oracle    operation_time>=date'2017-06-01'
MySQL                operation_time>= '2017-06-01'
6.关于银行账号业务反映自己不会处理
‘,’||h.account             字段||‘~’||字段  连接符的使用
7.业务提供的编码过多,在oracle中最多1000个
drop table t_zt_ky_bianma     –--删除临时表
create table t_zt_ky_bianma     --创建临时表
( customer_no varchar2(25) )
truncate table t_zt_ky_bianma   ---清空数据(下次直接用)
-- select count(*) from t_zt_ky_bianma –--查询验证
/* 插入编码  */
select * from t_zt_ky_bianma for update
 
8.create table detp_temp asselect * from dept  创建临时表(表中有数据)
 
IT~_%’ escape ‘~’ 此时_就不是通配符了
9.case …when…使用
 
case
         when w.CREATE_ORDER_TYPE is null then--不是返货
          tf.total_fee - tf.RESEND_FEE -tf.UNLOAD_FEE - tf.cod_amount
         else
          tf.SUMMARY_FEE - tf.RESEND_FEE -tf.UNLOAD_FEE - tf.cod_amount --是返货
       end as fee, -- 开单金额  
trunc(sysdate-1) 
 
nvl(r.dropoff_emp_name,r.create_name) 快递员姓名,
 
select * from pg_proc wherelower(prosrc) like '%t_exp_delivery_bus%' --查过程
 
sum(case when aa.isdelete=0and aa.is_waybill =1 then
                           1
                          else
                           0
                        end) 累计已开单,
 
DECODE(H.AUDIT_STATE_CODE,'201', '同意', '202', '不同意') AS 审批状态
 
SUBSTR(t.target_org_code,1,3)  提取一些字符

 

UNION用的比较多union all是直接连接,取到得是所有值,记录可能有重复 union 是取唯一值,记录没有重复