zoukankan      html  css  js  c++  java
  • MSSQL存储过程实现拼接sql的注意点

      这里我昨天碰到的问题就是执行一段根据变量tableName对不同的表进行字段状态的更改。由于服务器原因,我不能直接在数据访问层写SQL,所以只好抽离出来放到存储过程里面。

    这里就出现了一个问题,我花费了好久才弄通!

      其实就是很简单的一个SQL语句:

      update table1 set field1=value1,field2 = value2 where id = id

      我写成什么样子了呢?大家且看: 

      declare @tableName nvarchar(50),
    
          @field1 int,
    
          @field2 nvarchar,
    
          @id int
      declare @sql nvarchar(max)
    
      set @sql = 'update '+@tableName+' set field1= '+@field1+',field2= '+@field2+' where id='+@id
    
      exec @sql

      有过这方面经验的同学肯定知道这样写明显是错的,sql会报异常,说无法讲nvarchar转换成int类型

      那么这个错误是具体是值什么呢?其实就是说,在拼接sql的时候,这个@sql要是一个字符串类型,所有的变量也都必须用字符串表示,我上面的@field1和@id是int,所以要转化成nvarchar类型,并且是nvarchar类型的变量(字段)必须用单引号括起来;注:在sql中单引号是用两个单引号表示的

      所以经过修改,正确的拼接sql代码是:

      

    set @sql='update '+@tableName+ ' set field1='+cast(@field1 as varchar)+',field2='''+@field2+''' where id='+CAST(@id as varchar)

      这个问题其实非常简单,但是由于我在SQL方面的知识很是不足,所以在这里记录来巩固自己

      

  • 相关阅读:
    Number Two
    蝴蝶结
    webug3.0靶场渗透基础Day_1
    SQL SERVER2014的安装
    SQLILABS学习笔记(一)
    关于暴力破解的一些学习笔记(pikachu)
    sql注入学习笔记
    CSRF与平行越权的区别
    任意文件下载(pikachu)
    XSS跨站脚本攻击学习笔记(pikachu)
  • 原文地址:https://www.cnblogs.com/ms27946/p/5642440.html
Copyright © 2011-2022 走看看