在编写sql中,经常需要对sql进行预处理,动态拼接字符串,那么要获取在这预处理之后返回的的某个值并且赋值,传入参数的语法

  1. USE [OA]
  2. GO
  3. /****** Object: StoredProcedure [dbo].[usp_oa_UserMessageProve_Update] Script Date: 12/02/2014 10:45:19 ******/
  4. SET ANSI_NULLS ON
  5. GO
  6. SET QUOTED_IDENTIFIER ON
  7. GO
  8. /*
  9. 功能:更新用户证明数据,更新用户证明状态
  10. 2014.10.28 16:14 am
  11. */
  12. ALTER PROC [dbo].[usp_oa_UserMessageProve_Update]
  13. @msgid VARCHAR(10)
  14. ,@userid VARCHAR(10)
  15. ,@state VARCHAR(10)
  16. ,@remark VARCHAR(200)
  17. ,@filepath VARCHAR(200)
  18. AS
  19. begin
  20. DECLARE
  21. @tablename VARCHAR(100)
  22. ,@provered INT
  23. ,@sqlstr NVARCHAR(1000)
  24. ,@provepath VARCHAR(1000)
  25. ,@NOT_PROVE INT --未证明
  26. ,@CANNOT_PROVE INT --无法完成
  27. ,@HAS_PROVE INT --已证明
  28. --无法证明更新
  29. SELECT @NOT_PROVE=56,@CANNOT_PROVE=58,@HAS_PROVE=57
  30. select @tablename=tablename from ADM_F_GETUSERREADTABLE (@userid)
  31. IF @state = '1' -- state =1 执行无法证明操作
  32. BEGIN
  33. SET @sqlstr = 'update '+@tablename+' set proveremark='''+@remark+''',provered='+CAST(@CANNOT_PROVE AS VARCHAR(10))
  34. + ' where UserID='+@userid + ' and MessageID='+@msgid
  35. EXEC(@sqlstr)
  36. END
  37. ELSE IF @state = '2' -- state = 2 执行 按钮证明操作
  38. BEGIN
  39. SET @sqlstr = 'update '+@tablename+' set provered='+CAST(@HAS_PROVE AS VARCHAR(10))
  40. + ' where UserID='+@userid + ' and MessageID='+@msgid
  41. EXEC(@sqlstr)
  42. END
  43. ELSE IF @state = '3' -- state = 3 执行 文件路径更新操作
  44. BEGIN
  45. SET @sqlstr = 'update '+@tablename+' set provered='+CAST(@HAS_PROVE AS VARCHAR(10))+',provepath = isnull(provepath,'''')+ '''+@filepath
  46. +','' where UserID='+@userid + ' and MessageID='+@msgid
  47. EXEC(@sqlstr)
  48. END
  49. ELSE IF @state = '4' -- state = 4 执行文件删除更新操作
  50. BEGIN
  51. SET @sqlstr = 'select @provepath=provepath from '+@tablename+' where UserID='+@userid + ' and MessageID='+@msgid
  52. EXEC sp_executesql @sqlstr,
  53. N'@provepath VARCHAR(1000) output',
  54. @provepath OUTPUT
  55. SET @provepath= REPLACE(@provepath,@filepath+',','')
  56. SET @sqlstr = 'update '+@tablename+' set provepath = '''+@provepath+''''
  57. IF @provepath = ''
  58. BEGIN
  59. SET @sqlstr +=',provered='+CAST(@NOT_PROVE AS VARCHAR(10))
  60. END
  61. SET @sqlstr +=' where UserID='+@userid + ' and MessageID='+@msgid
  62. PRINT @sqlstr
  63. EXEC(@sqlstr)
  64. END
  65. END


sqlserver 针对预处理sql传入参数的处理方式的更多相关文章

  1. django模板传入参数的处理方式与反向生成url

    前端模板传入参数的处理方式 1.传入单个参数: 前端使用href="/sel-{{ row.0 }}.html, url使用url(r'sel-(.+).html',home.index), ...

  2. mysql 5.7.20 动态sql 传入参数

    drop procedure test; delimiter ;; CREATE procedure test() -- 取动态sql的值 -- 目前只测试出,在 where 后面, 可以用 ?,类似 ...

  3. sql 传入参数为逗号分隔的字符串处理方法

    写了个存储过程,中间用到了类似这种写法 Select * From User Where ID In('1,2,3') 其中'1,2,3'是从外面传进来的参数,就这样执行报错:'1,2,3'转换为in ...

  4. [ Database ] [ Sybase ] [ SQLServer ] sybase 與SQL Server的界接方式

    目前我們有個專案Server A安裝了 SQL Server 2012,有個需求需要連線到另外一台Server B上的 Sybase 12.5的view, 先前試過了很多方法都無法連通.主要的原因是因 ...

  5. C#中SQL语句参数写法

    OracleConnection oc=new OracleConnection("data source=osserver;User Id=****;password=**"); ...

  6. MyBatis传入参数为集合、数组SQL写法

    参考:http://blog.csdn.net/small____fish/article/details/8029030 foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合 ...

  7. 动态sql语句和动态传入参数个数

    1.可以将要传入的几个参数封装成一个实体类,然后将实体类作为一个参数传入到相应的方法中,这时候就需要这sqlMapper.xml文件中对传入的字段利用<if test=""& ...

  8. SQLSERVER procedure 传入参数为DataTable类型 C#该怎么写

    以上为数据库中存储过程传入参数为table类型 table类型在数据库中存在为: 最后在C#实现方式为:

  9. 预处理(防止sql注入的一种方式)

    <!--- 预处理(预编译) ---><?php/* 防止 sql 注入的两种方式: 1. 人为提高代码的逻辑性,使其变得更严谨,滴水不漏. 比如说 增加判断条件,增加输入过滤等,但 ...

随机推荐

  1. java String字符串

      五.java数据类型之String(字符串) CreateTime--2017年7月21日16:17:45 Author:Marydon (一)数据格式 (二)初始化 // 方式一 String ...

  2. exeption ORA-00907: missing right parenthesis

      exeption ORA-00907: missing right parenthesis CreationTime--2018年8月16日11点11分 Author:Marydon 1.情景展示 ...

  3. lambda 2

    # -*- coding: utf-8 -*- #python 27 #xiaodeng def action(x): return (lambda y:x+y) act=action(99) pri ...

  4. 在Loadrunner中如何用system函数执行系统命令

    前提: windows 系统 实现功能:用 LR 中的system函数执行系统命令 相关功能:在LR中利用C函数建立文件,写文件,读文件. 主要相关函数:sprintf/fopen/fgetc/fre ...

  5. Intellij IDEA 快捷键整理(dyCopy)

    原文:http://www.cnblogs.com/tonycody/p/3257601.html   [常规] Ctrl+Shift + Enter,语句完成 “!”,否定完成,输入表达式时按 “! ...

  6. 全栈JavaScript之路(十三)了解 ElementTraversal 规范

    支持Element Traversal 规范的浏览器有IE 9+.Firefox 3.5+.Safari 4+.Chrome 和Opera 10+. 对于元素间的空格,在IE9之前.都不会返回文档节点 ...

  7. 更改npm全局模块和cache默认安装位置

    来源于:http://blog.csdn.net/friendan/article/details/51736231 1.因为我安装的Node.js自带了npm,所以在nodejs文件夹里面新建以下两 ...

  8. Eclipse Xml编译错误Referenced file contains errors - spring-beans-4.0.xsd

    本文转自:http://josh-persistence.iteye.com/blog/2125420 在eclipse中,有时候在xml文件中,特别是于Spring相关的配置文件中,会出现一些不影响 ...

  9. linux下socket编程常用头文件

    sys/types.h:数据类型定义 sys/socket.h:提供socket函数及数据结构netinet/in.h:定义数据结构sockaddr_inarpa/inet.h:提供IP地址转换函数n ...

  10. python标准库介绍——1 os详解

    == os 模块 == ``os`` 模块为许多操作系统函数提供了统一的接口. 这个模块中的大部分函数通过对应平台相关模块实现, 比如 ``posix`` 和 ``nt. os`` 模块会在第一次导入 ...