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里面去
展开
 我来答
山水阿锐
推荐于2016-03-19 · TA获得超过34.3万个赞
知道顶级答主
回答量:23.7万
采纳率:91%
帮助的人:3.1亿
展开全部
您好,SqlCommand.ExecuteNonQuery 方法
对连接执行 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
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式