SqlParameter参数类型为int32时候的传值陷阱
2024-09-12 15:25:59
前2天在使用SqlParameter传递参数的时候遇到一个小坑,问题不大,重在分享。
SqlParameter para=new SqlParameter("@IsDeleted",0);
这样传递参数,到数据库执行的时候后面的参数将会变为default,当类型为int时必定产生错误。下面为正确的方法:
Parameter = new SqlParameter("@pname", Convert.ToInt32(0));
这是因为如果不执行该转换,则编译器将认为您尝试调用 SqlParameter(string、 SqlDbType)构造函数重载。
没错,你传递的0将会站位SqlDbType这个参数,调用public SqlParameter(string parameterName, SqlDbType dbType)方法。重载方法如下:
public SqlParameter(string parameterName, object value)
public SqlParameter(string parameterName, SqlDbType dbType)
因此当使用这个方法的时候,一定要将值传唤为object类型,哈哈,不能不说这个有点小坑,所以使用vs编码调用方法的时候最好多F12或者ctrl+shift键多看看。
最新文章
- Unit Of Work的设计
- jquery操作dom
- Java Io 字符流
- 安卓手机上运行 PC-E500 程序
- DataSanp的控制老大-DSServer
- WCF学习笔记(一)
- CoreAnimation3-专用图层
- WordPress批量修改文章内容、URL链接、文章摘要
- iOS的触摸事件
- php环境安装及搭建
- 应用facebook .net sdk
- C++函数调用
- jquery 学习笔记(1)
- zf-关于即将过期提示字符串的修改
- linux 细节 问题解决
- git clone操作到开发机的错误记录
- 01-01_环境准备_pyenv
- 【集训队作业2018】矩阵玩小凹 NTT
- vue打包上传oss
- [Java Web学习]JDBC事务处理