cmd.ExecuteNonQuery为啥返回1
IF(SUBSTR(name,1,2)<>'CC'THENp_flag:=0;/*RETURN;*/ELSESELECTNAME,WORKCREATOR,TO_CHAR(...
IF (SUBSTR(name,1,2)<>'CC' THEN
p_flag := 0;
/* RETURN;*/
ELSE
SELECT NAME,
WORK
CREATOR,
TO_CHAR(CREATEDATE, 'YYYY/MM/DD HH24:MI:SS')
INTO V_GATENAME,
V_WORKGROUP,
V_CREATOR,
V_CREATEDATE
FROM GATEAREAINFO
WHERE DELFLAG = 0;
IF SQL%FOUND
THEN
p_flag := 1;
ELSE
p_flag := -1;
END IF;
COMMIT;
END IF;
我输入的是if then里面的条件,test存储过程时p_flag = 0 但是代码中cmd.ExecuteNonQuery返回为1,明明没有修改任何东西,根本就没有跳到else里面去 展开
p_flag := 0;
/* RETURN;*/
ELSE
SELECT NAME,
WORK
CREATOR,
TO_CHAR(CREATEDATE, 'YYYY/MM/DD HH24:MI:SS')
INTO V_GATENAME,
V_WORKGROUP,
V_CREATOR,
V_CREATEDATE
FROM GATEAREAINFO
WHERE DELFLAG = 0;
IF SQL%FOUND
THEN
p_flag := 1;
ELSE
p_flag := -1;
END IF;
COMMIT;
END IF;
我输入的是if then里面的条件,test存储过程时p_flag = 0 但是代码中cmd.ExecuteNonQuery返回为1,明明没有修改任何东西,根本就没有跳到else里面去 展开
1个回答
展开全部
您好,SqlCommand.ExecuteNonQuery 方法
对连接执行 Transact-SQL 语句并返回受影响的行数。
返回值 受影响的行数。
备注: 您可以使用 ExecuteNonQuery 来执行目录操作(例如查询数据库的结构或创建诸如表等的数据库对象),或通过执行 UPDATE、INSERT 或 DELETE 语句,在不使用 DataSet 的情况下更改数据库中的数据。
虽然 ExecuteNonQuery 不返回任何行,但映射到参数的任何输出参数或返回值都会用数据进行填充。
对于 UPDATE、INSERT 和 DELETE 语句,返回值为该命令所影响的行数。对于所有其他类型的语句,返回值为 -1。如果发生回滚,返回值也为 -1。
在.NET中,ExecuteNonQuery方法返回受到Insert,Update 和 Delete 操作影响的行数。对于所有其他查询都返回 –1,而不是一般认为的0。
对连接执行 Transact-SQL 语句并返回受影响的行数。
返回值 受影响的行数。
备注: 您可以使用 ExecuteNonQuery 来执行目录操作(例如查询数据库的结构或创建诸如表等的数据库对象),或通过执行 UPDATE、INSERT 或 DELETE 语句,在不使用 DataSet 的情况下更改数据库中的数据。
虽然 ExecuteNonQuery 不返回任何行,但映射到参数的任何输出参数或返回值都会用数据进行填充。
对于 UPDATE、INSERT 和 DELETE 语句,返回值为该命令所影响的行数。对于所有其他类型的语句,返回值为 -1。如果发生回滚,返回值也为 -1。
在.NET中,ExecuteNonQuery方法返回受到Insert,Update 和 Delete 操作影响的行数。对于所有其他查询都返回 –1,而不是一般认为的0。
追问
可是我的存储过程条件只进到if里面,并没有任何有关UPDATE、INSERT 和 DELETE
的操作,为什麼返回为1
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询