zoukankan      html  css  js  c++  java
  • 从SqlServer的动态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

     

  • 相关阅读:
    Linq To Sql 大全
    lambda表达式学习
    一步一步学Linq to sql系列文章
    MVC 学习
    Guava环境设置
    ANT简介
    Quartz特点
    XStream环境设置
    log4j配置
    类是什么?
  • 原文地址:https://www.cnblogs.com/luluping/p/1659481.html
Copyright © 2011-2022 走看看