当前位置: 首页 > article >正文

ADO.NET知识总结4---SqlParameter参数

目录

5.1 SqlParameter介绍

5.2 SqlParameter创建参数方式

5.3 添加命令参数

5.4 参数使用


 

5.1 SqlParameter介绍

SqlParameter: 表示SqlCommand对象的参数,或与DataSet中列的映射

常用属性

DbType 参数的SqlDbType(即 数据库的类型而言)

Direction 参数的类型:输入\ 输出 \ 输入输出 \ 返回值参数

ParameterName 参数的名称

Size 最大大小 字节为单位

Value 参数的值

SqlValue 作为SQL类型的参数的值

5.2 SqlParameter创建参数方式

方式一用无参构造函数创建参数

SqlParameter pra1 = new SqlParameter();
pra1.ParameterName = "@userName";//参数名
pra1.SqlDbType = SqlDbType.VarChar;//数据类型
pra1.Value = "admin";//参数值
pra1.Size = 20;//大小

方式二以参数名和参数值创建参数

SqlParameter para2 = new SqlParameter("@cardNo", "2022090800001");

方式三:以参数名 和 SqlDbType 创建参数

SqlParameter para3 = new SqlParameter("@memberName", SqlDbType.Int);

方式四:以参数名、类型、大小 创建参数

SqlParameter para4 = new SqlParameter("@UserPwd", SqlDbType.VarChar, 50);
para4.Value = "123456";

方式五:以参数名、类型、大小、源列名(对应DataTable中的列名)

SqlParameter para5 = new SqlParameter("@UserName", SqlDbType.VarChar, 20, "UName");

5.3 添加命令参数

在条件查询中,可以不通过参数传递值,而是拼接生成SQL语句,并包含具体的值

但是拼接SQL:容易被SQL注入--钻空子,如何解决呢?----- 使用参数

参数的使用:防SQL注入、转义

Command添加参数的几种方法

  1. 添加单个参数
1.
    SqlParameter para=new SqlParameter("@userName","lingping");
cmd.Parameters.Add(para);  
2.
    cmd.Parameters.Add("@userName", "lingping");----这种已过时,基本不用
3.
cmd.Parameters.AddWithValue("@userName", "lingping");单个添加参数,推荐
  1. 添加参数数组
SqlParameter[] paras=new SqlParameter[]
{
    new SqlParameter("@userName","lingping"),
    new SqlParameter("@userPwd","123456")
    };
cmd.Parameters.AddRange(paras);   --添加参数数组

5.4 参数使用

平常用的参数,主要是指输入参数,参数还包含:输出参数、输入输出参数和返回值参数

输入参数参数化SQL语句存储过程中,默认使用的参数.

其他三种,主要用在存储过程里。

输出参数 存储过程里用 output 标识的参数

程序中是可以接收到存储过程里需要返回的值 而不是用return

Direction:Output

//定义输出参数
SqlParameter paraNo = new SqlParameter("@cardNo",SqlDbType.VarChar,50);
paraNo.Direction = ParameterDirection.Output;
cmd.Parameters.Add(paraNo);
//执行命令后,接收
cmd.ExecuteNonQuery();
conn.Close();
string reNo=paraNo.Value.ToString();

输入输出参数 存储过程里用output 进行标识,它需要传入值,也输出值,不用return

Direction:InputOutput

//定义输入输出参数
SqlParameter paraName = new SqlParameter("@memberName",SqlDbType.NVarChar,50);
paraName.Direction = ParameterDirection.InputOutput;
cmd.Parameters.Add(paraName);
//执行命令后,接收
cmd.ExecuteNonQuery();
conn.Close();
string reName=paraName.Value.ToString();

返回值参数
不出现在存储过程中 只可以返回的int类型 通过return 返回的值
Direction:ReturnValue

//定义输入输出参数
SqlParameter paraResult = new SqlParameter("@result",SqlDbType.Int);
paraResult.Direction = ParameterDirection.ReturnValue;
cmd.Parameters.Add(paraResult);
//执行命令后,接收
cmd.ExecuteNonQuery();
conn.Close();
int reVal=(int)paraResult.Value;//接收返回的值

http://www.kler.cn/a/488167.html

相关文章:

  • web作业
  • 《深度学习模型在鸿蒙分布式框架下的跨设备高效之旅》
  • 【蓝桥杯选拔赛真题60】C++寻宝石 第十四届蓝桥杯青少年创意编程大赛 算法思维 C++编程选拔赛真题解
  • ue5 蒙太奇,即上半身动画和下半身组合在一起,并使用。学习b站库得科技
  • ios脚本巨魔商店多巴胺越狱基本操作教程
  • SQL Server中可以通过扩展事件来自动抓取阻塞
  • Redis数据结构ZipList和QuickList原理解析
  • 工厂管理中 BOM(物料清单)
  • Linux Red Hat 7.9 Server安装Docker
  • 【数据库】二、关系数据库
  • Windows环境上传自己的源码工程到github
  • T-SQL语言的网络编程
  • Linux syslog 运行机制
  • 免费下载 | 2024安全有效性验证能力白皮书
  • LeetCode 热题 100_二叉树的最近公共祖先(48_236_中等_C++)(二叉树;深度优先搜索)
  • Qt 5.14.2 学习记录 —— 구 Buttons 常用控件
  • 怎么理解编码器与解码器?
  • 了解模2除法:原理与应用
  • 【股票数据API接口01】如何获取股票实时交易数据之Python、Java等多种主流语言实例代码演示通过股票数据接口获取数据
  • 模式识别-Ch2-分类错误率
  • 【SpringSecurity】二、自定义页面前后端分离
  • TDC-GP30 Data Sheet
  • 从 SQL 到 SPL:组内查找最近的匹配记录
  • 什么是负载均衡?NGINX是如何实现负载均衡的?
  • NO.3 《机器学习期末复习篇》以题(问答题)促习(人学习),满满干huo,大胆学大胆补!
  • 2025运维故障记 3 | 1/8左右 12306 4天3崩