数据库兼容,在开发项目过程中,难免会遇到 更改数据库,或者后期 项目升级,也可能会遇到这种情况,这里就说明下oralce和db2兼容开发注意事项。
兼容oralce、db2开发注意事项(前提是db2版本是9.7,且是开启PLSQL编译选项之后创建的数据库):
1. 在like 之后若使用了表字段,应统一改成使用locate函数
如:
oralce写法:
select * from fw_right a where '03' like a.rightid||'%';
兼容写法:
select * from fw_right a where locate('03',a.rightid) = 1;
oralce写法:
select * from fw_right a where '03' like '%'||a.rightid||'%';
兼容写法:
select * from fw_right a where locate('03',a.rightid) > 0;
2. 视图中使用的别名不应该与当前表字段同名
如以下语句,在Oracle中不会有问题,但在db2中会报"SQL0153N"错误:
e.g: CREATE OR REPLACE VIEW V_WF_TODOLIST AS select c.process_def_id, c.process_def_name, a.action_def_id, a.work_item_id, a.bae007, a.action_def_name, a.state, a.pre_wi_id, a.work_type, a.operid, a.x_oprator_ids, b.process_key_info, to_char(to_date(a.start_time, 'yyyymmddhh24miss'),'yyyy-mm-dd hh24:mi:ss') as start_time, to_char(to_date(a.complete_time,'yyyymmddhh24miss'),'yyyy-mm-dd hh24:mi:ss') as complete_time, a.filter_opr, a.memo,a.bae002,a.bae003, a.bae006,c.x_action_def_ids from wf_work_item a, wf_process_instance b, wf_action_def c where a.action_def_id = c.action_def_id and b.process_def_id = c.process_def_id and a.bae007 = b.bae007 and a.state in('0','2')
兼容写法:
CREATE OR REPLACE VIEW V_WF_TODOLIST AS select c.process_def_id, c.process_def_name, a.action_def_id, a.work_item_id, a.bae007, a.action_def_name, a.state, a.pre_wi_id, a.work_type, a.operid, a.x_oprator_ids, b.process_key_info, to_char(to_date(a.start_time, 'yyyymmddhh24miss'),'yyyy-mm-dd hh24:mi:ss') as start_time_0, to_char(to_date(a.complete_time,'yyyymmddhh24miss'),'yyyy-mm-dd hh24:mi:ss') as complete_time_0, a.filter_opr, a.memo,a.bae002,a.bae003, a.bae006,c.x_action_def_ids from wf_work_item a, wf_process_instance b, wf_action_def c where a.action_def_id = c.action_def_id and b.process_def_id = c.process_def_id and a.bae007 = b.bae007 and a.state in('0','2')
3.在下列情况下不允许 ORDER BY 或 FETCH FIRST n ROWS ONLY:
* 外层全查询视图
* "SQL 表函数"的 RETURN 语句中的外层全查询
* 具体化查询表定义
* 未用圆括号括起来的子查询
否则会报"SQL20211N 规范 ORDER BY 或 FETCH FIRST n ROWS ONLY 无效。"错误.
e.g:
oralce写法:
CREATE OR REPLACE VIEW V_FW_BLANK_BULLETIN as select id, bae001, operunitid, operunittype, unitsubtype, ifergency, title, content, digest, duetime, validto, aae100, bae006, bae002, bae003, id as colid, substr(digest,1,20) as digest2 from fw_bulletin where duetime <= to_char(sysdate,'yyyymmddhh24miss') and (to_char(validto) >= to_char(sysdate,'yyyymmddhh24miss') or validto is null) and aae100 ='1' order by ifergency desc, id desc, duetime desc
兼容写法:
CREATE OR REPLACE VIEW V_FW_BLANK_BULLETIN as select * from (select id, bae001, operunitid, operunittype, unitsubtype, ifergency, title, content, digest, duetime, validto, aae100, bae006, bae002, bae003, id as colid, substr(digest,1,20) as digest2 from fw_bulletin where duetime <= to_char(sysdate,'yyyymmddhh24miss') and (to_char(validto) >= to_char(sysdate,'yyyymmddhh24miss') or validto is null) and aae100 ='1' order by ifergency desc, id desc, duetime desc)
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
注意事项 禁止使用$_GET、$_POST、$GLOBALS、$_SERVER、$_FILES、$_COOKIE、$_SESSION、$_REQUEST、$_ENV等超全局变量 谨慎使用global、static关键字 不要在代码非协程环境中执行sleep以及其他睡眠函数,这样会导致整个进程阻塞. exit/die 是危险的,会导致 worker 进程退出 不要在业务代码中使用 swoole 不支
主要内容:1.使用注解的方式,2.封装条件判断的方式,3.集合返回值 数据库的属性 idea插件,4.判断集合类型不为空的正确方式1.使用注解的方式 2.封装条件判断的方式 3.集合返回值, 数据库的属性, idea插件 集合的返回值不可为null 映射数据库的属性劲量不用基本数据类型 控制方法复杂度的方式 4.判断集合类型不为空的正确方式
主要内容:1.拆分合理,2.与前端交互,3.返回值设置,4.项目推荐1.拆分合理 2.与前端交互 3.返回值设置 4.项目推荐 推荐使用lombock 不要AService调用BMapper 少写工具类, 代码冗余 使用新技术
主要内容:1.如何封装业务逻辑,2.如何封装方法形参1.如何封装业务逻辑 因为业务逻辑过多的话, 可以尽量的去封装业务逻辑, 可以达到代码的复用和冗余度降低的目的。 2.如何封装方法形参 可以写个对象出来进行封装。可以利用Builder模式创建一个对象。
本文向大家介绍PHP开发注意事项总结,包括了PHP开发注意事项总结的使用技巧和注意事项,需要的朋友参考一下 1.使用内嵌的HTML代码,而不是PHP的echo语句。 因为PHP是一门嵌入式Web编程语言,可以将HTML代码和PHP代码相互嵌入。但是很多程序员担心在HTML代码中过多的使用”"嵌入PHP代码会多次调用PHP解释器,从而降低了PHP代码的运行速度,所以宁愿使用PHP的echo语句来输出
DaoCloud 账号的注册 感谢您对 DaoCloud 的关注和支持,本文将带您一步一步地加入到 DaoCloud 的大家庭中。希望您能通过 DaoCloud 快速地学习并灵活地使用 Docker 进行项目代码的开发、测试和部署。 在使用 DaoCloud 提供的优质服务之前,您需要先注册一个属于您或您的团队的 DaoCloud 账号。DaoCloud 十分重视用户体验的简易性和灵活性,所以我们