ADO.NET之Parameter属性

简介: 在ADO.NET中, public SqlParameterCollection Parameters {get;}会得到一个SqlParameter属性。下面通过一个例子进行详细的认识吧。

在ADO.NET中,
public SqlParameterCollection Parameters {get;}会得到一个SqlParameter属性。下面通过一个例子进行详细的认识吧。

//例如在一个事件处理方法中有
using (SqlCommand cmd=new SqlCommand())
{
    try{
        cmd.Connection=conn;
        conn.Open();
        cmd.CommandType=CommandType.StoredProcedure;
        cmd.CommandText="INSERT";
        SqlParameter[] prams={
            new SqlParameter("@id",SqlDbType.VarChar,8);
            new SqlParameter("@name",SqlDbType.VarChar,50);
            new SqlParameter("@money",SqlDbType.Float);
            new SqlParameter("@age",SqlDbType.VarChar,50);
        };
        prams[0].Value=this.TextBox1.Text;
        prams[1].Value=this.TextBox2.Text;
        prams[2].Value=this.TextBox2.Text;
        prams[3].Value=this.TextBox3.Text;
        //添加参数
        foreach(SqlParameter parameter in prams){
        cmd.Parameters.Add(parameter);
        }
        SQlParameter sqlParameter=cmd.Parameters.Add("@Return",SqlDbType.Int);
        sqlParameter=ParameterDirection.ReturnValue;
        cmd.ExecuteNonQuery();
    }
    catch(Exception e){
        throw new Exception(e.Message);
    }
    int i=Convert.ToInt16(cmd.Parameters["@return"].Value.toString());
    if(i==1){
        MessageBox.Show("添加成功");
    }else if(i==-1){
        MessageBox.Show("添加过程失败");
    }
}
}
    ```


----------
总结:
这里的parameter数组实现的SQL过程就相当于Java里面的PreparedStatement的占位符方式,省去了sql语句书写易错的麻烦。
具体的使用步骤就是:

 - 先声明一个Parameter数组,
 - 然后为相应位置填充具体的含义(应该和要进行操作的数据库中对应的字段保持一致),
 - 然后就在可以在声明的特定的字段中获取到执行结果返回的值了。如

i=Convert.ToInt16(cmd.Parameters[“@return”].Value.toString());
``
便是从
SQlParameter sqlParameter=cmd.Parameters.Add(“@Return”,SqlDbType.Int);
sqlParameter=ParameterDirection.ReturnValue;`声明过之后用到的

目录
相关文章
|
API
.net core工具组件系列之Autofac—— 第二篇:Autofac的3种依赖注入方式(构造函数注入、属性注入和方法注入),以及在过滤器里面实现依赖注入
本篇文章接前一篇,建议可以先看前篇文章,再看本文,会有更好的效果。前一篇跳转链接:https://www.cnblogs.com/weskynet/p/15046999.html
629 0
.net core工具组件系列之Autofac—— 第二篇:Autofac的3种依赖注入方式(构造函数注入、属性注入和方法注入),以及在过滤器里面实现依赖注入
|
5月前
|
SQL 开发框架 .NET
(20)ASP.NET Core EF创建模型(必需属性和可选属性、最大长度、并发标记、阴影属性)
(20)ASP.NET Core EF创建模型(必需属性和可选属性、最大长度、并发标记、阴影属性)
|
JSON 前端开发 数据格式
.net MVC 使用 JSON JavaScriptSerializer 进行序列化或反序列化时出错,字符串的长度超过了为 maxJsonLength 属性设置的值
在.net mvc的controller中,方法返回JsonResult,一般我们这么写: [HttpPost] public JsonResult QueryFeature(string url, string whereClause) { string str=""; return Json(str); }   此时如果str过长,就会报“使用 JSON JavaScriptSerializer 进行序列化或反序列化时出错,字符串的长度超过了为 maxJsonLength 属性设置的值”。
2935 0
|
JSON 物联网 数据格式
阿里云物联网.NET Core客户端 CZGL.AliloTClient:5.设置设备属性
阿里云物联网.NET Core客户端 CZGL.AliloTClient:5.设置设备属性
382 15
|
存储 传感器 JSON
阿里云物联网.NET Core客户端|CZGL.AliloTClient:4.设备上报属性
阿里云物联网.NET Core客户端|CZGL.AliloTClient:4.设备上报属性
392 15
|
XML JSON 数据格式
.NET中XML序列化和反序列化常用类和用来控制XML序列化的属性总结(XmlSerializer,XmlTypeAttribute,XmlElementAttribute,XmlAttributeAttribute,XmlArrayAttribute...)
.NET中XML序列化和反序列化常用类和用来控制XML序列化的属性总结(XmlSerializer,XmlTypeAttribute,XmlElementAttribute,XmlAttributeAttribute,XmlArrayAttribute...)
279 0
|
存储 开发框架 自然语言处理
【.Net底层剖析】3.用IL来理解属性
【.Net底层剖析】3.用IL来理解属性
156 0
【.Net底层剖析】3.用IL来理解属性
|
存储 JSON 物联网
.NET Core 跨平台物联关网开发:上报属性(三)
.NET Core 跨平台物联关网开发:上报属性(三)
210 0
.NET Core 跨平台物联关网开发:上报属性(三)
|
JSON 物联网 网络性能优化
NET Core 跨平台物联网开发 SDK属性、方法、委托、类(四)
NET Core 跨平台物联网开发 SDK属性、方法、委托、类(四)
279 0
|
JSON 开发框架 前端开发
ASP.NET MVC中JSON强制小写属性名称
首先需要引用Newtonsoft.Json using Newtonsoft.Json; using Newtonsoft.Json.Serialization; 然后转换对象 Model.JsonResult jsonResult = new Model.
923 0