SQL Server 2005存储过程(转载)

size=large] 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://jerrysun.blog.51cto.com/745955/155313


原始出处:http://jerrysun.blog.51cto.com/745955/155313

作者信息:sw840227 的BLOG

唉,终于该开始数据操作了,累死我了。为什么非要写数据操作呢?其实写这个学习笔记之前是在使用存储过程操作数据的时候遇到了问题,为了记录这个问题,同时提醒自己要学习存储过程才写的这个笔记。言归正传,这个问题是什么呢?
  前面说了,我是在项目中遇到了使用存储过程的地方,所以才要写存储过程,开始写了一个存储过程,用来实现数据的插入操作,说白了就是添加数据。这个存储过程的代码如下:
  CREATE PROCEDURE PROC_INSERT_DATA_ID
        @DealerID varchar(50)
    AS
    BEGIN
        DECLARE @COUNT  INT   
       
        SET @COUNT = (SELECT COUNT(*) FROM myDATA_Details WHERE DealerID = @DealerID)
        IF (@COUNT>0)   
            BEGIN   
                DELETE FROM myDATA_Details WHERE DealerID = @DealerID   
                INSERT INTO myDATA_Details (DealerID) VALUES (@DealerID)   
            END   
        ELSE   
            BEGIN   
                INSERT INTO myDATA_Details (DealerID) VALUES (@DealerID)   
            END   
    END
  F5一下,创建成功,调用它插入数据,OK,没问题插入成功,达到了预期的目的。可是,我在建立第二个存储过程的时候,虽然将插入操作改为了更新,但是再像上面这么写就出错了,代码如下:
  CREATE PROCEDURE PROC_INSERT_DATA_DETAIL
        @DealerID varchar(50),
        @FieldName varchar(2000),
        @FieldValue varchar(2000)
    AS
    BEGIN
        DECLARE @Count INT
        SET @Count = (SELECT COUNT(*) FROM myDATA_Details WHERE DealerID = @DealerID)

        IF (@COUNT>0)
            BEGIN
                UPDATE myDATA_Details SET @FieldName = @FieldValue WHERE DealerID = @DealerID
            END
        ELSE
            BEGIN
                INSERT INTO myDATA_Details (DealerID) VALUES (@DealerID)
                UPDATE myDATA_Details SET @FieldName = @FieldValue WHERE DealerID = @DealerID
            END
    END
  语法OK,F5运行,也没有问题,兴奋啊,那就让它开始干活吧,咦,程序运行了呀,为什么没有更新呢,莫非是抛出异常了?赶紧,进Visual Studio 2005里Debug一下吧,走你,一路F11,没有问题啊,该调用的都调用了,也没有报错啊,那是怎么回事呢?存储过程?没道理吧!还是看看印度人是怎么写的吧,果然和我写的不一样,根据印度人的代码,对我建立的存储过程加以修改,修改完毕后再次运行程序,嗯,不错,这回终于是给我干活了。还是很有成就感的嘛,哈哈。
附:修改后的代码
  ALTER PROCEDURE PROC_INSERT_DATA_DETAIL
        @DealerID varchar(50),
        @FieldName varchar(2000),
        @FieldValue varchar(2000)
    AS
    BEGIN
        DECLARE @Count INT
        DECLARE @StrSQL VARCHAR(2000)
        SET @Count = (SELECT COUNT(*) FROM myDATA_Details WHERE DealerID = @DealerID)

        IF (@COUNT>0)
            BEGIN
                SET @StrSQL = 'UPDATE myDATA_Details SET '+ @FieldName + ' = ''' +@FieldValue + ''' WHERE DealerID = '+ @DealerID
                EXEC(@StrSQL)
            END
        ELSE
            BEGIN
                INSERT INTO myDATA_Details (DealerID) VALUES (@DealerID)
                SET @StrSQL = 'UPDATE myDATA_Details SET '+ @FieldName + ' = ''' +@FieldValue + ''' WHERE DealerID = '+ @DealerID
                EXEC(@StrSQL)
            END
    END

本文出自 “徘徊在c#,java,php之间” 博客,请务必保留此出处http://jerrysun.blog.51cto.com/745955/155313
[/size]

猜你喜欢

转载自fantaoyalin.iteye.com/blog/1586018
今日推荐