返回顶部
首页 > 资讯 > 精选 >如何使用CLR存储过程来传回讯息
  • 733
分享到

如何使用CLR存储过程来传回讯息

2023-06-17 20:06:31 733人浏览 泡泡鱼
摘要

这篇文章主要介绍如何使用CLR存储过程来传回讯息,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!CLR存储过程存放于类别库项目 SendYouDataReader 中,它示范如何使用 sqlPipe 对象的 Send

这篇文章主要介绍如何使用CLR存储过程来传回讯息,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

CLR存储过程存放于类别库项目 SendYouDataReader 中,它示范如何使用 sqlPipe 对象的 Send 方法将查询结果(也就是 SqlDataReader 类别对象)直接传送至客户端。特别要再次说明的是,虽然 Send 方法的执行效率略低于 ExecuteAndSend 方法,但是在数据被传送至客户端之前,Send 方法能够提供***的弹性来处理数据,换句话说,如果您希望传送先前通过同处理序(In-Process)提供者所执行的查询结果,或是想要利用 SqlDataReader 的自订实作来预先处理数据,请使此多载版本的 Send 方法。完成之后的程序代码如下所示:

using Microsoft.SqlServer.Server;   namespace SendYouDataReader  { public class SendYouDataReaderClass   { [Microsoft.SqlServer.Server.SqlProcedure()]   public static void SendYouDataReader(decimal LowerSalary, decimal HigherSalary)  { SqlCommand cmd; SqlDataReader dr; // 使用内容连接来进行连接。   using (SqlConnection connection = new SqlConnection("context connection=true"))   { connection.Open();   cmd = new SqlCommand( "SELECT 员工编号,姓名,目前薪资 FROM dbo.章立民研究室 " + "WHERE 目前薪资 BETWEEN @LowerSalary AND @HigherSalary", connection);  cmd.Parameters.AddWithValue("@LowerSalary", LowerSalary);  cmd.Parameters.AddWithValue("@HigherSalary", HigherSalary);  dr = cmd.ExecuteReader(); // 呼叫 SqlPipe 对象的 Send 方法将查询结果直接传送给客户端 SqlContext.Pipe.Send(dr); }   }   }   }

请执行如下所示之 SQL 指令,登录组件 SendYouDataReader.dll、建立一个参考所登录之组件 SendYouDataReader.dll 的存储过程、然后执行此 CLR 存储过程,执行结果如图表 1 所示:

USE 北风贸易;  Go   IF EXISTS (SELECT * FROM sys.procedures WHERE [name] = 'SendYouDataReader') DROP PROCEDURE SendYouDataReader;   GO  IF EXISTS (SELECT * FROM sys.assemblies WHERE [name] = 'SendYouDataReader') DROP ASSEMBLY SendYouDataReader;   GO -- 登录组件SendYouDataReader.dll CREATE ASSEMBLY SendYouDataReader FROM   'C:\SQL2005Demo\CH13\SendYouDataReader\SendYouDataReader\bin\ SendYouDataReader.dll' WITH permission_set = Safe;   GO -- 建立一个会参考所登录之组件SendYouDataReader.dll 的存储过程   CREATE PROCEDURE dbo.SendYouDataReader ( @LowerSalary money, @HigherSalary money )   AS EXTERNAL NAME SendYouDataReader.[SendYouDataReader.SendYouDataReaderClass].SendYouDataReader;  GO EXEC sp_configure 'clr enabled', '1';  GO RECONFIGURE;   GO DECLARE @return_value int -- 执行CLR 存储过程   EXECUTE @return_value = dbo.SendYouDataReader @LowerSalary = 50000, @HigherSalary = 70000;

如何使用CLR存储过程来传回讯息

以上是“如何使用CLR存储过程来传回讯息”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: 如何使用CLR存储过程来传回讯息

本文链接: https://lsjlt.com/news/293034.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何使用CLR存储过程来传回讯息
    这篇文章主要介绍如何使用CLR存储过程来传回讯息,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!CLR存储过程存放于类别库项目 SendYouDataReader 中,它示范如何使用 SqlPipe 对象的 Send ...
    99+
    2023-06-17
  • 怎么利用CLR存储过程传回信息
    怎么利用CLR存储过程传回信息,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。CLR存储过程存放于类别库项目SendYouDataReader 中,它示范如何使用 SqlPi...
    99+
    2023-06-17
  • 如何在SQL Server中创建和使用CLR存储过程
    在SQL Server中创建和使用CLR存储过程需要以下步骤: 创建CLR程序集:首先需要创建一个包含CLR存储过程的程序集。可以使用Visual Studio或者其他CLR开发工具来创建这个程序集。 将程序集部署到SQL Serv...
    99+
    2024-06-03
    sql server
  • 如何使用hive存储过程
    这篇文章给大家分享的是有关如何使用hive存储过程的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。hive存储过程简介1.x版本的hive中没有提供类似存储过程的功能,使用Hive做数据开发时候,一般是将一段一段的...
    99+
    2023-06-02
  • oracle如何使用存储过程
    存储过程是一组可存储在数据库中的 sql 语句,可作为独立单元重复调用。它们可以接受参数(in、out、inout),并提供代码重用、安全性、性能和模块化的优势。示例:创建存储过程 ca...
    99+
    2024-06-13
    oracle 敏感数据
  • Mysql存储过程有什么作用?如何使用存储过程?
    Mysql自5.0起就支持存储过程,存储过程通俗的讲就是在一段封装过的SQL,但不仅仅只有SQL那么简单,通常还会有变量、条件判断、循环体,游标等。存储过程的作用在很多场景中,需要将多个表的数据处理,来产生...
    99+
    2024-04-02
  • oracle中如何使用存储过程
    这期内容当中小编将会给大家带来有关oracle中如何使用存储过程,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。 1.基本结构 CREATE OR REPLAC&...
    99+
    2024-04-02
  • oracle中存储过程如何使用
    今天就跟大家聊聊有关oracle中存储过程如何使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一. 使用for循环游标:遍历所有职位为经理的雇员1...
    99+
    2024-04-02
  • MySQL中如何使用存储过程
    这篇文章将为大家详细讲解有关MySQL中如何使用存储过程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 使用CallableStatemen...
    99+
    2024-04-02
  • php+mysql如何使用存储过程
    这篇文章主要介绍“php+mysql如何使用存储过程”,在日常操作中,相信很多人在php+mysql如何使用存储过程问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php+my...
    99+
    2023-04-19
    mysql php
  • oracle如何通过存储过程上传list保存功能
    这篇文章将为大家详细讲解有关oracle如何通过存储过程上传list保存功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、创建oracle 需要保存的数据类型type和存储过程producecreat...
    99+
    2023-06-15
  • 如何在Python中使用Git和Shell来优化存储过程?
    随着数据量的不断增长,存储过程的优化变得越来越重要。在Python中,我们可以使用Git和Shell来优化存储过程,从而提高数据处理效率。本文将介绍如何使用Git和Shell来优化存储过程,并演示相关代码。 Git的使用 Git是一款分...
    99+
    2023-08-13
    git shell 存储
  • 如何在mysql中使用存储过程
    如何在mysql中使用存储过程?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。存储过程包含了一系列可执行的sql语句,存储过程存放于MySQL中...
    99+
    2024-04-02
  • Sql Server存储过程中如何调用存储过程接收输出参数返回值
    这篇文章将为大家详细讲解有关Sql Server存储过程中如何调用存储过程接收输出参数返回值,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。创建存储过程:AL...
    99+
    2024-04-02
  • MySql中如何使用存储过程参数
    MySql中如何使用存储过程参数,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。存储过程 in参数 的使用IN参数只用来向过程传...
    99+
    2024-04-02
  • SQLServer存储过程中事务如何使用
    SQLServer存储过程中事务如何使用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。具体代码如下create pr...
    99+
    2024-04-02
  • 如何使用mysql存储过程中的if
    这篇文章主要介绍了如何使用mysql存储过程中的if,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 在mysql...
    99+
    2024-04-02
  • MySQL存储过程的参数如何使用
    这篇文章主要介绍“MySQL存储过程的参数如何使用”,在日常操作中,相信很多人在MySQL存储过程的参数如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL存储过...
    99+
    2024-04-02
  • 如何在 PHP 中使用 MySQL 存储过程?
    要在 php 中使用 mysql 存储过程:使用 pdo 或 mysqli 扩展连接到 mysql 数据库。准备调用存储过程的语句。执行存储过程。处理结果集(如果存储过程返回结果)。关闭...
    99+
    2024-05-11
    mysql php
  • sql如何获取存储过程返回数据
    这篇文章给大家分享的是有关sql如何获取存储过程返回数据的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。就是在执行存储后,获取存储过程执行的数据并作为其他应的二次使用,其实在代码中...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作