唉,终于该开始数据操作了,累死我了。为什么非要写数据操作呢?其实写这个学习笔记之前是在使用存储过程操作数据的时候遇到了问题,为了记录这个问题,同时提醒自己要学习存储过程才写的这个笔记。言归正传,这个问题是什么呢?
前面说了,我是在项目中遇到了使用存储过程的地方,所以才要写存储过程,开始写了一个存储过程,用来实现数据的插入操作,说白了就是添加数据。这个存储过程的代码如下:
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