日常导数过程中对三种数据库的理解

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

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 是取唯一值,记录没有重复

你可能感兴趣的:(数据库学习笔记)