免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2196 | 回复: 8
打印 上一主题 下一主题

Oracle中如何建存储过程! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-06-21 15:48 |只看该作者 |倒序浏览
请各位大侠指点!很急!!!

论坛徽章:
0
2 [报告]
发表于 2007-06-22 08:30 |只看该作者
直接写啊 createproc 。。。。

论坛徽章:
0
3 [报告]
发表于 2007-06-22 09:00 |只看该作者
有些知识是需要自己去看书的,一切勤为王道。

论坛徽章:
0
4 [报告]
发表于 2007-06-22 10:00 |只看该作者

回复 3楼 numenhuang 的帖子

谢谢各位高手,我有一个sql server的存储过程,想改成Oracle的,我对Oracle不太熟,请指教

论坛徽章:
0
5 [报告]
发表于 2007-06-22 10:01 |只看该作者
参见下面这个帖子的一楼
http://bbs.chinaunix.net/viewthr ... &extra=page%3D1

论坛徽章:
0
6 [报告]
发表于 2007-06-22 10:01 |只看该作者
CREATE PROC GRP_OP
@ID                INT,                        /* 输入-表ID */
@DEPARTMENT_ID        SMALLINT,
@USERNAME        VARCHAR(32),
@Op                TINYINT,                /* 输入-操作类型 0--插入,1--修改,2--删除 */
@ReturnID        INT OUTPUT,
@Explain        VARCHAR(32) OUTPUT        /* 输出-错误消息 */
AS
DECLARE @OLD_DEPARTMENT_ID        smallint
DECLARE @OLD_USERNAME                varchar(32)

SET @ReturnID=-1
SET @Explain='未知错误类型'

IF @Op = 0  /* 插入 */
  IF (SELECT USERNAME FROM SMBS_USERS WHERE DEPARTMENT_ID=@DEPARTMENT_ID AND USERNAME=@USERNAME AND GRP=1) IS NOT NULL /* 是否存在该名称 */
    BEGIN
     SET @Explain='在组中已存在 ' + @USERNAME
     RETURN
    END
  ELSE
    BEGIN
      INSERT INTO SMBS_USERS(DEPARTMENT_ID,USERNAME, GRP) VALUES (@DEPARTMENT_ID,@USERNAME,1)
      SELECT @ReturnID=USER_ID FROM SMBS_USERS WHERE DEPARTMENT_ID=@DEPARTMENT_ID AND USERNAME=@USERNAME AND GRP=1
    END
IF @Op = 1  /* 修改 */
  BEGIN
    SELECT @OLD_DEPARTMENT_ID=DEPARTMENT_ID,@OLD_USERNAME=USERNAME FROM SMBS_USERS WHERE USER_ID=@ID
    IF ((@OLD_DEPARTMENT_ID != @DEPARTMENT_ID) OR (@OLD_USERNAME != @USERNAME))
      IF (SELECT USERNAME FROM SMBS_USERS WHERE DEPARTMENT_ID=@DEPARTMENT_ID AND USERNAME=@USERNAME AND GRP=1) IS NOT NULL
        BEGIN
          SET @Explain='在组中已存在 ' + @USERNAME
          RETURN
        END
      ELSE
        BEGIN
          UPDATE SMBS_USERS SET DEPARTMENT_ID=@DEPARTMENT_ID,USERNAME=@USERNAME WHERE USER_ID=@ID
          SELECT @ReturnID=USER_ID FROM SMBS_USERS WHERE DEPARTMENT_ID=@DEPARTMENT_ID AND USERNAME=@USERNAME AND GRP=1
        END
  END
IF @Op = 2  /* 删除 */
  EXECUTE GRP_DELETE @ID
SET @Explain='执行成功'
RETURN
GO
下面的if我不知道怎么改

论坛徽章:
0
7 [报告]
发表于 2007-06-22 10:38 |只看该作者
这个是学习上的问题还是工作上的问题
如果是学习上的问题:
这个如果只是针对这个procedure,LZ并没能学到什么,PL/SQL应该要系统的学习
如果是工作上的问题:
这个procedure搞定了,那下一个呢?

论坛徽章:
0
8 [报告]
发表于 2007-06-22 10:43 |只看该作者
学习是不可避免的,就是别人帮你改好代码,那调试和功能修改呢。

论坛徽章:
0
9 [报告]
发表于 2007-06-22 11:10 |只看该作者

回复 8楼 numenhuang 的帖子

我就是想问一下那三个if在Oracle中怎么改?我原来没有接触到这样的,都是些简单的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP