ado.net 参数传递之 in
之前项目有一放行的功能,对某界面维护时(数据的增删改),先将数据保存到临时表中,放行后再真正的写入到库中。由于设计到主从表多中约束关系,所以当时我采用的是写一个存储过程来对某个界面的操作进行统一处理,具体参见关于MVC项目中的主管放行。现在sa 说不得使用存储过程为由让更改(开发文档中写明: 尽量少用存储过程),自以为仅仅是将sql 挪一个位置,实际在修改中 在 in 这个地方还是费了不少时间。
在谈及 in 之前,先说下参数传递的三种方式
1. 字符串拼接 ' "+str+" ' ,很容易理解,好用,所谓的字符串拼接,对于非前台界面传入的参数可以直接这样写,可避免sql 注入,前台输入的参数若直接用此方法,则可被sql注入
2. Parameter ,也常见,常规的操作直接传入参数即可 如update: set A.name = @name 此处name经过sql 编译后 自动会加入单引号 ' '
3. 占位符 {0},用String.Format 拼接,当某段sql中存在出现多次相同的参数时,用此方法比较方便,如果用2,则要写para1,para2 ,para3,若用3,只需要写一个 ‘{0}’
上面的搞清楚了,现在来看一看 in 这个比较特殊的问题,当传递的参数本身就包含逗号时,就比较搅了,如 'a1,b1','a2,b2','a3,b3'
诸如: 用到IN的存储过程,需要转两个弯弯,先用EXEC( ' ' ) 包裹一遍,然后里面所用到的值都要加一个单引号,如 '' D'' , 对于IN后带@的参数,为 '+@str+',普通的参数加两对单引号
'''+@appuserid+'''
EXEC('
--刪除
DELETE FROM A
WHERE TableKey IN
(SELECT TableKey FROM tempA WHERE sFlag = ''D'' AND ApplyUserID = '''+@appuserid+''' AND TableKey IN('+@str+'))
--清空臨時資源表
DELETE FROM tempZT_SysConfig_Master WHERE TableKey IN ('+@str+');
')
诸如:一般不需要用到存储过程、事务和IN关键字的SQl 而言,直接写入即可(成功)
SELECT * FROM A WHERE ApplyUserID = @ApplyUserID
诸如:带 IN 关键字的SQl,单个参数中不含逗号,如: 'A,B,C',或者参数含逗号,如 'a1,b1','a2,b2','a3,b3',采用如下方式去执行Sql,则为失败;若采用Trim('\'') 去掉首尾单引号,仍然失败。(采用 ExecuteScalar 去获取值,不报错,单结果为 0,正常应该为2)
SELECT COUNT(*) FROM A WHERE ApplyUserID IN(@ApplyUserID)
尝试了许久,最终改用占位符 { 0 } 解决,注: 普通占位符加单引号,IN 后面则不需要
SELECT COUNT(*) FROM A WHERE ApplyUserID IN({0}) AND NAME = '{1}'
其实占位符还有一个好处,由于之前写的储存过程中涉及的参数 @ApplyUserID 和 @Name 用到了多次,若使用字符串拼接觉得比较丑(小小的强迫症),若采用@Parameter 则需要定义很多变量,因为SQL中 Parameter 变量不能重复,而且碰到 IN 这种弯弯,绕起来又比较麻烦,故用占位符 {0} ,实际上操作起来很方便,对于sql中出现多次 @ApplyUserID 用 {0} 代替,@Name用 {1} 代替即可。占位符无关次数。
ado.net 参数传递之 in的更多相关文章
- ADO.NET 帮助类 参数传递 存储过程 分页
SQLHelper public class SqlHelper { private readonly string _constr = ConfigurationManager.Connection ...
- C# ADO.NET SqlDataAdapter中传递参数
ADO.NET的SQL语句中,往往不是静态的语句,而是需要接受传递过来的参数,比如典型的登录功能,需要查找指定的用户名: string sqlQuery = "SELECT * FROM W ...
- ADO.NET事务处理,初始回调函数,多张表的数据在同一个DataGridView中展示
执行ADO.NET事务包含四个步骤,接下来以Transaction对象为例介绍. (1)调用SQLConnection对象的BeginTransaction()方法,创建一个SQLTransactio ...
- .NET基础操作回顾_使用ADO.NET操作SqlServer使用的类
有些工具用的久了或者有新工具出现后,就慢慢的遗忘了很多,它们从熟悉的变成陌生,当然,对于我们来说不是好事吧. 今天回顾一下ADO.NET用到的MS的基础类库,先上代码(标准的SqlServer操作) ...
- ado.dataset
DataSet是ADO.NET的中心概念.可以把DataSet当成内存中的数据库,DataSet是不依赖与数据库的独立数据集合.所谓独立,就是说,即使断开数据链路,或者关闭数据库,DataSet依然是 ...
- 从一个Bug说开去--解决问题的思路,Linked Server, Bulk Insert, DataTable 作为参数传递
声名— 部分内容为杜撰,如有雷同,不胜荣幸! 版权所有,如要引用,请标明出处! 如果打赏,请自便! 1 背景介绍 最近一周在忙一个SQL Server 的Bug,一个简单的Bug,更新两张 ...
- ADO面板上的控件简介
ADO面板上的控件简介 一. TADOConnection组件该组件用于建立数据库的连接.ADO的数据源组件和命令组件可以通过该组件运行命令及数据库中提取数据等.该组件用于建立数据库的连接,该连接可被 ...
- C# 6 与 .NET Core 1.0 高级编程 - 37 章 ADO.NET
译文,个人原创,转载请注明出处,有不对的地方欢迎指出与交流. 英文原文:Professional C# 6 and .NET Core 1.0 - 37 ADO.NET --------------- ...
- Delphi7 ADO面板上的控件简介
? ADO Connection的主要方法:1) Begin Trans 开始启动一个新的事务,必须保证数据连接处于激活状态.2) Cancel 关闭于数据库的连接.3) Commit T ...
随机推荐
- [整理]Linux Crontab命令总结
一.crontab命令的基本介绍 crontab命令常见于Unix和类Unix的操作系统之中,用于设置周期性被执行的指令.该命令从标准输入设备读取指令,并将其存放于"crontab" ...
- spring mvc的跨域解决方案
什么是跨域 一句话:同一个ip.同一个网络协议.同一个端口,三者都满足就是同一个域,否则就是跨域. 为什么非得跨域 基于两个方面: a. web应用本身是部署在不同的服务器上 b.基于开发的角度 -- ...
- Angular02 通过angular-cli来搭建web前端项目
利用angular-cli的常见命令: npm i --save 包名 -> 软件依赖 npm i --save-dev 包名 -> 开发依赖 ng new 项 ...
- 微积分入门("SX"T版)
哎,微积分,表示暂时并没有很深入的研究……虽然高中有教,但是好像跟小西瓜学的顺序不太一样,嗯……教微积分之前不应该把极限学下来么……不管了,本文按傻X腾的理解来搞吧. 极限……大学的东西喔,我们先来认 ...
- [bzoj1500 维修数列](NOI2005) (splay)
真的是太弱了TAT...光是把代码码出来就花了3h..还调了快1h才弄完T_T 号称考你会不会splay(当然通过条件是1h内AC..吓傻)... 黄学长的题解:http://hzwer.com/28 ...
- win10清除桌面快捷方式小箭头
reg add /d "%systemroot%\system32\imageres.dll,197" /t reg_sz /f taskkill /f /im explorer. ...
- JS中const、var 和let的区别
今天第一次遇到const定义的变量,查阅了相关资料整理了这篇文章.主要内容是:js中三种定义变量的方式const, var, let的区别. 1.const定义的变量不可以修改,而且必须初始化. 1 ...
- 再起航,我的学习笔记之JavaScript设计模式29(节流模式)
节流模式 概念介绍 节流模式(Throttler): 对重复的业务逻辑进行节流控制,执行最后一次操作并取消其他操作,以提高性能. 优化滚动事件 有的时候我们再为滚动条添加动画的时候,会发现滚动条不停的 ...
- Sql Server——数据增删改
所谓数据的增删改就是在创建好数据库和表后向表中添加数据.删除表中的数据.更改表中的一些数据. 新增数据: 语法一: insert into 表名 values (数据内容) --这里需要 ...
- JavaScript变量声明与提升
一直以来对变量提升都是比较模糊的,今天特地看了一下这个知识点,总结一下. 1.举个最简单的例子来说一下什么是变量提升吧. function foo(){ console.log(x); // unde ...