机房重构——Pramaters_变量名 '@UserID' 已声明。变量名在查询批次或存储过程内部必须唯一

本文主要是介绍机房重构——Pramaters_变量名 '@UserID' 已声明。变量名在查询批次或存储过程内部必须唯一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    背景:这两天一直在弄登陆和退出的工作记录的写入和修改,然而就在这两天出了这么一个错“变量名 '@UserID' 已声明。变量名在查询批次或存储过程内部必须唯一”,这是在下机的时候,写下机记录的时候出现的错误,然后系统一直在报这个错误,只要登陆成功一次就报,异常退出之后再登陆就没有事,这一切都与数据操作中的Pramaters有关。


一、Pramaters介绍

        他的全名就叫做SqlCommand.Parameters,在微软的官方解释中:The Microsoft .NET Framework Data Provider for SQL Server does not support the question mark (?) placeholder for passing parameters to a SQL Statement or a stored procedure called by a command of CommandType.Text. In this case, named parameters must be used. For example:
    SELECT * FROM Customers WHERE CustomerID = @CustomerID


        这就表示了这个Pramaters是和CommandType.Text是有关系的,那么什么又是CommandType.Text呢?其实这个问题在sqlhelper中有明确的提示,就是这一句:


cmdType = CommandType.StoredProcedure '定义命令方式为存储过程 

        

        这句活就是设置查询方式是用SQL语句查询还是用存储过程来查询,CommandType.Text就是定义用SQL语句来查询,这里面就用到了Parameters,这个Prameters就是一个placeholder for passing parameters,什么意思呢,就是占位符传递参数,说白了就是一个传递数据的参数集,里面包含了数据,@CustomerID就是加了数据的参数,数据暂时存储在了Parameters里面。

二、为什么要使用Parameters呢?

        其实在vb6.0的机房里面我们就有过接触,就是sql注入这个问题,只要不对输入的字符进行规定,就会导致注入错误,而在ADO.NET中引入了Parameters这个占位符传递参数,就是为了避免这类的问题,先把数据给Parameters,然后再用sql语句去调用,就有了一个转化的作用:

Dim paras As SqlParameter() = {New SqlParameter("@UserID", WorkLog.UserID), New SqlParameter("@Computer",WorkLog.Computer)}      'WorkLog为工作记录的实体
Dim cmdText As String cmdText = "select * from Work_Log_Info where UserID=@UserID and Offdate is null and Computer=@Computer" 参数化调用数据

其中参数就是代表了实体中的属性值的一个跳板。

 

三、为什么会出现标题的问题

        在写数据的时候是不用返回值的,所以我把SQLHelper改了一下,又定义了一个函数来处理没有返回值得情况:

Public Sub AlterUpdate(ByVal cmdText As String, ByVal cmdType As CommandType, ByVal paras As SqlParameter())cmd.CommandText = cmdText                                             '获取SQL语句的具体内容cmd.CommandType = cmdTypecmd.Parameters.AddRange(paras)  ' 参数添加 Tryconn.Open()cmd.ExecuteNonQuery()Catch ex As ExceptionMsgBox(ex.Message.ToString())FinallyCall CloseCmd(cmd)CloseConnection(conn)End Try
End Sub

        

        由于当时的不理解,少了一句话,就是cmd.Parameters.Clear(),由于第一次使用的时候没有清空Parameters的内容,所以在第二次调用的时候,Parameters里面默认已经有了@UserID这个字符,所以才会报这个已经存在的错误,然而第二次登陆的时候,由于我的判断机制,没有用到这个函数,所以没有执行,就没有报错。所以,Parameters在使用时候是一定要清空的,这一点一定要注意。


四、总结

        通过了这次的调错的历程,让我对于ADO.NET的数据查阅又有了新的理解,以后再有类似的问题,再也不怕了。


这篇关于机房重构——Pramaters_变量名 '@UserID' 已声明。变量名在查询批次或存储过程内部必须唯一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922054

相关文章

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

MYSQL查询结果实现发送给客户端

《MYSQL查询结果实现发送给客户端》:本文主要介绍MYSQL查询结果实现发送给客户端方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql取数据和发数据的流程(边读边发)Sending to clientSending DataLRU(Least Rec

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Spring Boot 整合 Apache Flink 的详细过程

《SpringBoot整合ApacheFlink的详细过程》ApacheFlink是一个高性能的分布式流处理框架,而SpringBoot提供了快速构建企业级应用的能力,下面给大家介绍Spri... 目录Spring Boot 整合 Apache Flink 教程一、背景与目标二、环境准备三、创建项目 & 添

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.