作者:liigo
日期:2010/8/25
原创:http://blog.csdn.net/liigo/archive/2010/08/24/5834450.aspx
转载请注明出处:http://blog.csdn.net/liigo
Microsoft SQL SERVER 数据库存储过程,根据其输入输出数据,笼统的可以分为以下几种情况或其组合:无输入,有一个或多个输入参数,无输出,直接返回(return)一个值,通过output参数返回一个或多个值,返回一个记录集(recordset)。无论哪一种情况,无论输入输出参数多复杂的存储过程,都可以在易语言中正确调用,准确的传入参数,并获取正确的输出数据。下面我(liigo)分多种情况介绍在易语言中调用MS SQL SERVER数据库存储过程的详细方法,使用数据库操作支持库(eDatabase.fne)。此前多有人说易语言无法调用数据库存储过程,或咨询调用存储过程的方法,因成此文。
一、调用“无输入输出数据”的存储过程
这是最简单的情况,执行一个简单的SQL语句就OK了,下面直接给出代码:
其中,“数据库连接1”是数据库操作支持库中“数据库连接”控件的实例,"exec" 表示调用存储过程,"dbproc"为被调用的存储过程的名称。即使存储过程有返回值,在不想接收返回值的情况下,也可按这种方法调用。
二、调用“有一个或多个输入参数”的存储过程
一个输入参数的情况(其中5为参数值,跟在存储过程名称之后,以空格分隔):
两个输入参数的情况(其中3和6为参数值,之间以逗号分隔):
三、调用“返回记录集(recordset)”的存储过程
存储过程最后一条SQL语句为Select语句,通常将返回一个记录集(recordset)给调用者。在易语言中,可通过数据库操作支持库中的“记录集”控件接收该记录集,具体代码如下图:
核心代码就是中间淡黄底色加亮的那一行(记录集1.打开),这行代码执行成功后,记录集1内容就是存储过程返回的recordset内容,通过一个简单的循环语句可以遍历所有记录。实际使用中,应检查“记录集1.打开”调用是否成功,上图为简化起见省略之。
下文更复杂的情况,也是用大概相同的代码,仅中间淡黄底色加亮的那一行有所变化。
四、调用“返回记录集(recordset)且有一个或多个输入参数”的存储过程
代码与前面大致相同,只是调整了中间一行调用存储过程的SQL语句的写法,前面都有涉及,无需多言:
五、调用“直接返回(return)一个值”的存储过程
此类返回值相当于易语言子程序的返回值,是在存储过程代码内部使用 return 指令返回的。欲得到这个返回值,稍微有点麻烦,且看代码:
这里面我(liigo)用了三条SQL语句(严格来说是Transact-SQL语句),各语句之间以分号分隔。第一条 "declare @R int" 定义了一个类型为 int 的变量 @R,第二条 "exec @R = dbproc_r" 调用存储过程并把其返回值赋值给变量@R,第三条,"select @R" 生成一个只有一条记录和一个字段的记录集。代码执行成功后,读取 记录集1 第一条记录第一个字段就得到了存储过程的返回值,完整代码可参考前图。实际应用中,应注意存储过程返回值类型的匹配。@R改成@abc都无所谓,但@符号必须保留(变量或参数的前缀)。
如果这个存储过程还有输入参数呢?直接把参数值附加在存储过程名称后面即可,形如:记录集1.打开 (“declare @R int; exec @R = xproc_r_p2 3,6; select @R”, #SQL语句, )。
六、调用“通过OUTPUT参数返回值”的存储过程
存储过程中有一种output参数既是输入参数又是输出参数,它的值可被存储过程内部改写。大概相当于易语言子程序的“参考”参数。调用代码如下:
仍然是借助一个变量@P得到输出参数的值(注意类型要匹配),然后生成一个单记录单字段的记录集,执行成功后通过记录集1读取该字段值即可。调用存储过程的SQL语句 "exec xproc_o @P output" 中,output表示这个参数可以接收返回值。
七、调用“同时存在返回值和OUTPUT参数”的存储过程
这是前面两种情况的综合运用,可借助多个变量解决,代码形如:记录集1.打开 (“declare @R int; declare @P1 int; declare @P2 int;exec @R = xproc_r_p3 100,@P1 output,@P2 output; select @R,@P1,@P2”, #SQL语句, )。
八、思考:调用“既有OUTPUT参数(或返回值)又返回记录集”的存储过程
我(liigo)暂时无解。
附,相关测试用存储过程代码:
全文完。
分享到:
相关推荐
总结,易语言调用MS SQL SERVER数据库存储过程的关键在于构建正确的SQL语句,并使用适当的数据库操作支持库函数。通过理解这些基本方法,开发者可以灵活地处理各种存储过程,无论是简单的数据操作还是复杂的业务逻辑...
在"易语言源码SQLserver数据库操作例程.rar"这个压缩包中,包含了使用易语言进行SQL Server数据库操作的相关示例代码和说明文档。 首先,我们要理解SQL Server是微软公司推出的一款关系型数据库管理系统,广泛应用...
5. 存储过程与函数的调用:SQL Server支持存储过程和用户自定义函数,这些可以在易语言中通过执行SQL语句调用。调用存储过程和函数时,需要将参数传递进去,并接收返回的结果。 6. 错误处理和事务管理:在数据库...
对于那些希望通过易语言进行数据库操作的学习者来说,了解如何在易语言环境中操作SQL Server数据库是非常重要的。本文将详细介绍从创建数据库到执行基本的增删改查操作的全过程。 #### 二、创建数据库及表结构 ...
SQL Server是微软公司推出的关系型数据库管理系统,广泛应用在各种规模的企业中,提供了高效、稳定的数据存储与管理功能。 本例程的核心是介绍如何使用易语言来操作SQL Server数据库,这包括了连接数据库、执行SQL...
在IT领域,数据库管理系统(DBMS)是至关重要的组成部分,SQL Server是Microsoft公司推出的一款功能强大的关系型数据库管理系统,广泛应用于企业级数据存储和管理。本文将深入探讨使用易语言进行SQL Server数据库...
在易语言中,可以通过内置的数据库接口来操作SQL Server数据库。这通常涉及以下步骤: 1. **建立连接**:使用易语言的数据库模块,输入正确的数据库服务器地址、用户名、密码以及数据库名,创建数据库连接。 2. **...
【易语言操作SQL Server数据库全过程】这篇文章主要介绍了如何在易语言环境下与SQL Server数据库进行交互。易语言是一种中文编程语言,适用于初学者和专业人士。在本文中,作者以创建一个员工信息表为例,逐步讲解了...
总结,易语言操作SQL Server数据库的过程主要包括创建数据库、建立连接、编写SQL语句以及处理查询结果。通过熟练掌握这些步骤,开发者可以轻松地在易语言环境中实现对SQL Server数据库的各种操作,从而满足不同业务...
易语言操作SQL Server数据库全过程 易语言操作SQL Server数据库的全过程可以分为三个步骤:建立数据库、建立数据库连接和使用SQL命令。 步骤一:建立数据库 在易语言中,首先需要建立一个数据库。以建立一个员工...
"易用SQL命令操作SQL2000和ACCESS.e"很可能是一个易语言编写的程序或者教程文档,它提供了一系列的函数或方法,使开发者能够方便地在易语言中与SQL Server 2000和ACCESS数据库进行交互。可能包含了如何连接数据库、...
sql,易语言源码易语言SQLserver数据库操作例程
输入数据库地址、用户名、密码、数据库名,工具连接数据库,如果...因为项目中,数据库地址及库名有可能会更换,直接将连接信息保存到INI文件或写死,不安全或不便更改,本工具可以做为易语言sqlserver程序的辅助工具。
在易语言中,我们可以使用内置的数据库访问模块,如ODBC(Open Database Connectivity)或ADO(ActiveX Data Objects),来与SQL Server等数据库进行交互。备份通常涉及执行SQL的“BACKUP DATABASE”命令,将整个...
9. **存储过程和函数**:在需要执行复杂逻辑或重复操作时,可以创建SQL的存储过程和函数,并在易语言中调用。 在压缩包中的“易语言SQL全面操作数据库源码”文件中,包含了以上各种操作的实例代码,通过阅读和分析...
在IT领域,数据库是存储和管理数据的核心工具,而SQL Server是Microsoft公司开发的一款功能强大的关系型数据库管理系统。本文将详细解析"易语言-使用SQLserver数据库登录和注册例程"这一主题,帮助读者理解如何在...