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

     

  • 相关阅读:
    Qt拖放功能
    CUDA笔记 -- 1
    c/c++笔记--5
    SpringBoot注解大全
    Java集合图谱
    sql优化的几种方法
    Spring 体系结构详解
    2019年 Java 面试题解析
    IntelliJ IDEA 快捷键大全
    java集合继承关系
  • 原文地址:https://www.cnblogs.com/luluping/p/1659481.html
Copyright © 2011-2022 走看看