今天是工作的第一天,被老总要求写db2存储过程,关键是之前并没有学过这个,然后还了解到不同的数据库的存储过程是不太一样的,DB2的存储过程还没有教学的视屏或者详细的文章讲解,学的很吃力。感觉这个点是个问题,以后有技术出来,也不会有相应的文章和讲解,要慢慢摸索解决的方案。
就我今天接触的来说,存储结构给我的感觉就像一个放在数据库的方法一样,他可以传入参数,但是传出的是结果集,也就是resultset的类型对象。感觉上是可以把业务逻辑封装在里面,从而简化业务层或持久层的代码。
问题1:
模糊查询,以传入的参数作为条件,要用||将参数和%链接起来,如: '%'||v_companyid||'%';
问题2:
排序的时候北京,上海,重庆,天津等直辖市要排在最前面,需要指定这些数据在最前面,用decode函数。
order by decode(provname,'北京',1,'上海',2,'天津',3,'重庆',4)
这样北京排在第一,上海排在第二,天津排在第三,重庆排在第四。
如遇到空值时, order by 默认将空值排在最下面,如要排在最上面,则:
模糊查询,以传入的参数作为条件,要用||将参数和%链接起来,如: '%'||v_companyid||'%';
问题2:
排序的时候北京,上海,重庆,天津等直辖市要排在最前面,需要指定这些数据在最前面,用decode函数。
order by decode(provname,'北京',1,'上海',2,'天津',3,'重庆',4)
这样北京排在第一,上海排在第二,天津排在第三,重庆排在第四。
如遇到空值时, order by 默认将空值排在最下面,如要排在最上面,则:
--用DROP PROCEDURE 存储过程名字来删除一个存储过程。</