| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1998 人关注过本帖
标题:vfp 调用SQL 存储过程返回值?自创?
取消只看楼主 加入收藏
mywisdom88
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:191
帖 子:3147
专家分:8408
注 册:2015-3-25
结帖率:98.98%
收藏
已结贴  问题点数:5 回复次数:2 
vfp 调用SQL 存储过程返回值?自创?
我在网上找了很多,关于VFP 调用SQL 存储过程的返回值,都没什么好的结果。有的说用OUTPUT参数。。
以下是我自己做法,不知道OUTPUT的做法是怎么样的?
在SQL2000中建立存储过程

ALTER PROCEDURE [dbo].[get_insert]  --或者 CREATE PROCEDURE
@u_name varchar(20)
AS
declare @awr nvarchar(10)
BEGIN
 SET NOCOUNT ON;
if exists(select u_name from users where u_name=@u_name)
 begin
   SET @awr='Yes'
    --存在,你要做的其他操作
 end
else
 begin
 SET @awr='No'
    --不存在,你要做的其他操作,比如可以插入这个名称的记录
 end
select @awr AS 'Answer'  --把作为查询返回
END
GO

**在VFP中调用方法
u_name='李四'
awr=SQLEXEC(nhandle,'exec get_insert @u_name=?u_name ','AAA')
IF awr>0
   SELECT AAA
   IF UPPER(Answer)=[YES]
      MESSAGEBOX([记录操作成功])
   ELSE
      MESSAGEBOX([记录操作失败])
   ENDIF
   USE
ELSE
   MESSAGEBOX([操作存储过程失败])
ENDIF
这样做的好处,我知道我执行SQLEXEC()后的操作,是不是成功插入,修改了记录。系统返回的-1,1等,只能知道执行这个命令没错误。
比如我
u_name='88888'
SQLEXEC(nhandle,'exec get_insert @u_name=?u_name ','AAA')
这个值是1,但表users有没 u_name='88888'这个记录,看这个1是看不出来,但现在用我这个存储方法。。
不知道用OUTPUT的方法是怎么样的?求解答
搜索更多相关主题的帖子: 网上 where 
2015-07-03 17:37
mywisdom88
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:191
帖 子:3147
专家分:8408
注 册:2015-3-25
收藏
得分:0 
另外:怎么把这个存储过程,通过用VFP写到SQL2000去?我现在是直接在SQL查询分析器上建立的。。。
2015-07-03 17:45
mywisdom88
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:191
帖 子:3147
专家分:8408
注 册:2015-3-25
收藏
得分:0 
现在,使用存储过程的现象已经比较少了。比较多的是 vfp 直接写代码控制 SERVER.非常灵活方便??
但如果直接控制?如果我编号字段BH,要求是唯一的,但我又不想在SQL2000限制为主索引,不用自增字段,
那我在增加数据的时候,SQLEXEC(nhandle,insert ...)时,怎么知道我增加成功呢?或者怎么知道不重复呢?
如果我用了像我上面的存储过程,我在存储过程中处理,返回1个值,我就知道我成功增加了没。
2015-07-04 11:28
快速回复:vfp 调用SQL 存储过程返回值?自创?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015838 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved