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

news/2025/1/9 21:04:02 标签: .net, 数据库, c#, 开发语言

目录

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.niftyadmin.cn/n/5817984.html

相关文章

java实验6 J.U.C并发编程

实验6 J.U.C并发编程 要求: 1)严禁上网抄袭、互相抄袭和各种形式的抄袭(如代码抄袭,运行截图一图多用),一旦发现单次作业按零分处理! 2)课程报告正文内容基本格式为:…

Visio 画阀门 符号 : 电动阀的画法

本篇文章介绍阀门,很多朋友在利用Visio绘画管道流程简图时,需要进行阀门符号的绘画,而Visio提供的阀门符号种类并不是很齐全。 本篇文章给出电动阀的画法: 下图是液动阀的符号: 首先,找到“更多形状”中的…

Oracle:ORA-00904: “10“: 标识符无效报错详解

1.报错Oracle语句如下 SELECT YK_CKGY.ID,YK_CKGY.DJH,YK_CKGY.BLRQ,YK_CKGY.ZBRQ,YK_CKGY.SHRQ,YK_CKGY.YT,YK_CKGY.ZDR,YK_CKGY.SHR,YK_CKGY.BZ,YK_CKGY.JZRQ,YK_CKGY.ZT,YK_CKGY.CKLX,(case YK_CKGY.CKLXwhen 09 then药房调借when 02 then科室退药when 03 then损耗出库when…

如何用Python编程实现自动整理XML发票文件

传统手工整理发票耗时费力且易出错,而 XML 格式发票因其结构化、标准化的特点,为实现发票的自动化整理与保存提供了可能。本文将详细探讨用python来编程实现对 XML 格式的发票进行自动整理。 一、XML 格式发票的特点 结构化数据:XML 格式发票…

在idea中配置多个版本的jdk

问题:有时候有好几个项目,不同的项目用的是不同版本的jdk。 在oracle官网下载多个版本的jdk https://www.oracle.com/cn/java/technologies/downloads/选择exe版本安装 如果只在idea里使用的话,就不需要配置环境变量了。只需要在项目结构里a…

【计算机网络】课程 实验五 静态路由配置

实验五 静态路由配置 一、实验目的 理解静态路由的工作原理,掌握如何配置静态路由。 二、实验分析与设计 【背景描述】 假设校园网分为 2 个区域,每个区域内使用 1 台路由器连接 2 个子网, 现要在路由器上 做适当配置,实现校…

系统架构设计师考点—信息安全和网络安全

一、备考指南 信息安全和网络安全主要考查的是信息安全属性、加密解密数字摘要、数字签名、PKI体系等相关知识,同时也是重点考点,在系统架构设计师的考试中一般会考选择题,占2~4分,在案例分析和论文中有时也会考到,属于…

蓝桥杯python省赛备战day2--连续求和公式应用--829连续整数求和-枚举算法刷题学习笔记2--leetcode

写在前面的话: 大家好,我是一名正在努力学习数据结构和算法的新手。这篇文章是我在学习python的各类数据结构以及基础算法过程中的一些笔记和心得,希望能和同样在学习该方面知识的朋友们分享。由于我的知识有限,文章中可能存在错…