`
weitd
  • 浏览: 143357 次
  • 性别: Icon_minigender_1
  • 来自: 新都
社区版块
存档分类
最新评论

动态Sql 返回值

 
阅读更多
这是使用动态Sql的人都会碰到这样的问题,需要从动态执行的sql中返回值,下面给一个简单的实现例子。


IF EXISTS(SELECT * FROM SYSOBJECTS WHERE NAME = 'ValueFromSql')
   DROP PROC ValueFromSql
GO
create proc ValueFromSql

 as begin

declare @value varchar(100)


exec sp_executesql N'select @value=''From Sql'' ',N'@value varchar(100) out ',@value out

print @value


end


执行结果为; From Sql

如果想把sql语句当成变量传入,定义应该如下,注意@sql的类型应该是nvarchar

IF EXISTS(SELECT * FROM SYSOBJECTS WHERE NAME = 'ValueFromSql')
   DROP PROC ValueFromSql
GO
create proc ValueFromSql

 as begin

declare @value varchar(100)
declare @sql nvarchar(4000)

set @sql='select @value=''From Sql'' '

exec sp_executesql @sql,N'@value varchar(100) out ',@value out

print @value


end

分享到:
评论

相关推荐

    动态SQL 并且把返回的值赋给变量

    ### 动态SQL 并且把返回的值赋给变量 在SQL Server中,动态SQL是一种强大而灵活的工具,允许开发人员根据运行时条件构建并执行SQL查询。本文将详细介绍如何利用`sp_executesql`来执行动态SQL,并重点讨论如何将执行...

    php动态检测sql返回值

    有的时候检测sql更新前端页面,比如这个人有没有优惠券,有没有购物车,有没有其他设置,后端就会有多张表的读取,返回的东西有和没有,逻辑上的if else多,复杂,代码量还多,就写了个动态的判断然后返回。...

    oracle动态sql之EXECUTE IMMEDIATE.docx

    2. 如果需要从动态 SQL 返回值,则可以定义返回值变量,BULK COLLECT INTO 返回多行值,此时定义的变量需是数组变量的列表或记录表类型;INTO 返回单行,此时定义的变量可以使多个 PL/SQL 变量的列表或记录类型。 3....

    mysql存储过程 在动态SQL内获取返回值的方法详解

    在动态SQL中获取返回值是存储过程的一个重要功能,尤其在处理不确定的数据结构和条件时。本篇文章将深入探讨如何在MySQL存储过程中实现这一目标。 首先,我们来看一个示例存储过程,它实现了通用的分页查询功能。在...

    本地动态SQL的开发

    ### 本地动态SQL的开发 #### 一、动态SQL的概念 动态SQL是在程序运行时构建并执行的SQL语句,其内容无法在编译时完全确定。与静态SQL(如常见的`UPDATE`语句)不同,动态SQL允许开发者在运行时根据实际情况构建...

    Oracle动态SQL之本地动态SQL的使用.pdf

    Oracle数据库系统提供了对动态SQL的支持,这是一种在程序运行时构建和执行SQL语句的编程技术,对于实现数据库操作的灵活性具有重要作用。本文将探讨Oracle本地动态SQL的使用方法和技巧。 动态SQL的使用场景广泛,它...

    动态SQL在PowerBuilder中的应用.pdf

    1. 无返回值无输入参数的动态SQL 这种类型的动态SQL通常用于执行那些不需要返回结果集,也不依赖外部参数的数据库操作,例如执行一个纯粹的更新、删除操作。在PB中编写这种类型的动态SQL时,只需要构造相应的SQL语句...

    VB.NET 2008调用SQL存储过程并返回值示例

    总的来说,VB.NET 2008调用SQL Server存储过程涉及到创建数据库连接、定义命令对象、设置参数、执行存储过程并处理返回值和异常。这个过程允许开发者高效地与数据库交互,同时处理可能发生的错误情况。

    执行带回参动态SQL的带回参存储过程

    本主题将深入探讨如何执行带回参动态SQL的带回参存储过程,以及与之相关的概念,如动态SQL、存储过程中的参数处理和回参。 动态SQL是在运行时构建的SQL语句,它允许程序根据条件或用户输入来决定执行什么SQL操作。...

    Sql Server 存储过程调用存储过程接收输出参数返回值

    创建存储过程: ALTER PROCEDURE [dbo].[GetCustomers] (@rowcount INT OUTPUT) AS SELECT [CustomerID] ,[CompanyName] ,[ContactName] ,[ContactTitle] ,[Address] ...SET @rowcount=@@rowcount

    C#存储过程的细致使用+接收sql的返回值

    本文将详细介绍C#如何使用存储过程,以及如何接收SQL存储过程的返回值。 首先,存储过程(Stored Procedure)是一组预编译的SQL语句,它在数据库服务器上预先定义并存储,可以被多次调用执行,降低了网络通信的负担...

    在Developer_2000编程中实现动态SQL语句调用的研究.pdf

    在数据库应用程序开发中,动态SQL语句的使用是提高程序灵活性、通用性和可维护性的关键手段。动态SQL语句允许在程序执行时根据用户的输入或运行时的参数决定具体的SQL语句,使应用程序能够执行事先不确定的SQL操作。...

    根据动态链接库的提示,传入不同的参数,就可以调用生成SQL

    根据动态链接库的提示,传入不同的参数,就可以调用生成SQL

    SSM笔记-动态SQL

    8. **bind标签**:bind标签允许在SQL语句中引用Java方法的返回值,简化SQL。例如: ```xml ()"/> WHERE status IN ((" separator="," close=")">#{item}) ``` 9. **sql标签**:sql标签可以复用SQL片段,提高...

    有返回值SQL Server存储过程的一个调用方法.pdf

    调用有返回值SQL Server存储过程的一些方法 本文主要讲解了如何调用有返回值的SQL Server存储过程,以提高Power Builder程序的运行效率和系统的易维护性和扩展性。通过实例,阐述了调用有返回值的SQL Server存储...

    MyBatis学习之三动态SQL语句[借鉴].pdf

    【MyBatis动态SQL语句详解】 在MyBatis中,动态SQL是一种强大的功能,它允许我们在XML映射文件中根据不同的条件构建SQL语句,极大地提高了代码的灵活性和可维护性。本篇将深入探讨MyBatis的动态SQL语句,主要关注`...

    SQL Server 中 EXEC 与 SP_EXECUTESQL 的区别.doc

    在SQL Server中,动态执行SQL语句有两个主要的命令:`EXEC`和`SP_EXECUTESQL`。两者都用于在运行时执行SQL语句,但它们之间存在显著的区别。 一、EXEC `EXEC`命令可以执行存储过程或者动态SQL语句。当我们需要执行...

    如何获得PreparedStatement最终执行的sql语句

    在实际应用中,如果需要获取动态构建的SQL,可能需要自定义一个`PreparedStatement`的代理类,覆盖`execute`或`executeQuery`方法,然后在这个代理类中拼接和打印出最终的SQL。但这需要对JDBC有深入的理解,并且需要...

Global site tag (gtag.js) - Google Analytics