一.三种数据库管理系统简介:
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 是取唯一值,记录没有重复