【Sql Server】C#通过拼接代码的方式组合添加sql语句,会出现那些情况,参数化的作用

欢迎来到《小5讲堂》,大家好,我是全栈小5。
这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解,
特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!

在这里插入图片描述

目录

  • 前言
  • 语句报错
  • 报错原因
  • 参数优化
  • ADO.NET
  • 安装包
  • 链接模式
  • 参数化作用
  • 文章推荐

前言

博主写的很多博客分享,都是来源于实际开发和学习过程中遇到的一些细节问题,
因此通过文章的方式记录下来,这不仅可以边写边总结边边理解,这样也能加深印象。
本篇文章是讲,为什么要用参数化来生成sql语句?通过创建测试项目一起探索吧!

语句报错

没有进行参数化传递值,通过纯拼接方式组合的sql语句,是有可能存在一些sql语句不规范,
从而导致一些报错,比如:博主本次sql语句报错就是因为sql语句存在参数值本身还有逗号,
逗号在sql语句里又是特殊符号。
在这里插入图片描述上图报错提示,在张三附近有语法错误,这个时候如果不是具体分析sql语句,但从错误提示是看不出什么原因。

在这里插入代码片

报错原因

通过调试和查看sql语句,观察可以看到,在赋值时,如果粗心大意的话,是很容易多写了一次单引号
在这里插入图片描述

参数优化

基于上面错误,如果赋值确实需要带上单引号进行查询,那么就需要通过参数化的方式。
添加一条记录测试,具体创建表可以在文章后面查看相关链接

declare @agent_name nvarchar(50)
set @agent_name='''张三'''

insert into test_name(city_name,area_name,agent_name)
values('深圳市','龙岗区',@agent_name)

从下图可以看到,使用参数化可以传递单引号值,也不会引发sql语句报错在这里插入图片描述

ADO.NET

在 C# 的 ADO.NET 中,以下是一些基本的类及其主要作用:

1.SqlConnection
用于建立与 SQL Server 数据库的连接。

2.SqlCommand
用于执行 SQL 语句或存储过程,并返回受影响的行数、结果集或标量值。

3.SqlDataAdapter
用于从数据库中读取数据,并填充到 DataSet 或 DataTable 中。
可以直接执行sql语句,如果没有where条件或者参数化时

4.DataSet
本身不包含数据,但是可以包含一个或多个 DataTable ,以及它们之间的关系。

5.DataTable
表示内存中的表格,包含多个 DataRow,一行表示一条记录,包含多个列(字段)。

6.DataRow
表示 DataTable 中的一行数据,通过列名或索引访问数据。

安装包

和十年前VS开发工具相比,现在VS版本越来越智能化,会自动识别进行包的安装,非常方便和高效。在这里插入图片描述

链接模式

C# ADO.NET 链接字符串两种模式,一个是要账号密码,一种是不需要账号密码。
在 C# 中使用 ADO.NET 连接数据库时,连接字符串通常包含数据库连接所需的信息。
如果采用 Windows 身份验证方式连接数据库,连接字符串通常不需要包含明确的用户名和密码,因为它会使用当前 Windows 用户的身份验证信息。这就是 “Windows 身份验证” 模式。
下面是一个使用 Windows 身份验证的连接字符串示例:

string connectionString = "Data Source=ServerName;Initial Catalog=DatabaseName;Integrated Security=True;";

如果使用的是 SQL Server 身份验证方式连接数据库,那么连接字符串需要包含用户名和密码信息。
下面是一个使用 SQL Server 身份验证的连接字符串示例:

string connectionString = "Data Source=ServerName;Initial Catalog=DatabaseName;User ID=UserName;Password=Password;";

参数化作用

通过上面代码分析,参数化的其中一个作用,能够规范化进行传参,避免和sql本身有重复的值。
除了这个作用外,还有其他作用,比如:

1.预防 SQL 注入攻击
通过使用参数化查询,可以确保用户输入的数据不会被误解为 SQL 代码的一部分,从而有效地防止 SQL 注入攻击。因为参数化查询会将用户输入的数据作为数值或文本来处理,而不是作为可执行的 SQL 代码。

2.提高代码可读性和可维护性
使用参数化查询可以将 SQL 查询语句与参数值分离开来,使代码更清晰易懂。这样的设计有助于提高代码的可读性和可维护性,减少了混杂在一起的 SQL 代码和参数值所带来的混乱。

3.提高执行效率
数据库服务器通常会对参数化查询进行缓存和优化,因此可以提高查询的执行效率。通过将参数化查询参数化,数据库可以更好地重复使用预编译的查询计划,从而减少了解析和编译 SQL 查询语句的开销。

4.避免数据类型问题
使用参数化查询可以根据参数的数据类型来正确地将参数值传递给数据库,避免了在某些情况下需要手动对数据进行类型转换的问题。

文章推荐

【Sql Server】Update中的From语句,以及常见更新操作方式

【Sql server】假设有三个字段a,b,c 以a和b分组,如何查询a和b唯一,但是c不同的记录

【Sql Server】新手一分钟看懂在已有表基础上修改字段默认值和数据类型

【数据库】Sql Server数据迁移,处理自增字段赋值

【数据类型】C#和Sql Server、Mysql、Oracle等常见数据库的数据类型对应关系

总结:温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/430308.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【C++从0到王者】第四十七站:最小生成树

文章目录 一、最小生成树的概念1.概念2.最小生成树的构造方法 二、Kruskal算法1.算法思想2.代码实现 三、Prim算法1.算法思想2.代码实现3.试试所有节点为起始点 一、最小生成树的概念 1.概念 连通图:在无向图中,若从顶点v1到顶点v2有路径,则…

这本书太好了!150页就能让你上手大模型应用开发

如果问个问题:有哪些产品曾经创造了伟大的奇迹?ChatGPT 应该会当之无愧入选。 仅仅发布 5 天,ChatGPT 就吸引了 100 万用户——当然,数据不是关键,关键是其背后的技术开启了新的 AI 狂潮,成为技术变革的点火…

强势改进!基于改进多目标灰狼算法的冷热电联供型微电网运行优化程序代码!

适用平台:MatlabYalmipCplex 程序以综合能源系统/微电网为研究对象,将微电网的运行费用和环境污染成本作为优化目标,考虑冷热电负荷和设备运行要求的约束,建立的微电网的多目标优化模型,使用改进多目标灰狼算法算法进…

有个朋友被骗了,大家要擦亮眼睛

1.引言 大家好,我是Leo哥🫣🫣🫣,昨天凌晨有个粉丝朋友找到Leo哥,咨询一些问题,现在的朋友们真卷呐,大半夜还在挑灯夜战。可无奈Leo哥12点之前已经睡了,身体为重&#xf…

智慧社区养老:Java与SpringBoot的技术融合

✍✍计算机毕业编程指导师 ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java、…

Day31|贪心算法1

贪心的本质是选择每一阶段的局部最优,从而达到全局最优。 无固定套路,举不出反例,就可以试试贪心。 一般解题步骤: 1.将问题分解成若干子问题 2.找出适合的贪心策略 3.求解每一个子问题的最优解 4.将局部最优解堆叠成全局最…

C语言第三十五弹---文件操作(上)

✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】 文件操作 1、为什么使用文件? 2、什么是文件? 2.1、程序文件 2.2、数据文件 2.3、文件名 3、二进制文件和文本文件 4、文件的打开和…

YOLO v9训练自己数据集

原以为RT-DETR可以真的干翻YOLO家族,结果,!!!! 究竟能否让卷积神经网络重获新生? 1.数据准备 代码地址:https://github.com/WongKinYiu/yolov9 不能科学上网的评论区留言 数据集…

【Python】新手入门(2):避免将关键字作为标识符

Python新手入门(2):避免将关键字作为标识符 🌈 个人主页:高斯小哥 🔥 高质量专栏:Matplotlib之旅:零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入门教程&#x1…

蓝桥杯-单片机组基础7-存储器映射扩展与PWM脉冲调制(附小蜜蜂课程代码)

蓝桥杯单片机组备赛指南请查看这篇文章:戳此跳转蓝桥杯备赛指南文章 本文章针对蓝桥杯-单片机组比赛开发板所写,代码可直接在比赛开发板上使用。 型号:国信天长4T开发板(绿板),芯片:IAP15F2K6…

【Python】matplotlib绘制图像时增加颜色条

一、需求 plt.imshow()是matplotlib中的一个函数,用于显示图像。它可以传递一个二维或三维数组作为image参数, 并将图像数据显示为图形,并对图像进行不同的可视化设置。 在显示的过程中,我们如果需要增加一个图例显示颜色条&…

Word转Excel怎么操作?4个实用技巧别忘了!

“我在处理一个Word文件时,需要将里面的一些表格内容转化为Excel。有什么比较好用的Word转Excel方法可以推荐吗?” 在互联网时代,数据处理和信息整合是工作中不可或缺的一部分。有时,我们可能会遇到需要将Word文档中的数据或内容转…

高性能深度学习库luminal

一、概述 Luminal是一个深度学习库,它使用可组合的编译器来实现高性能。 当前的机器学习库往往很庞大复杂,因为它们试图直接将高级操作映射到底层手工编写的内核上,并且专注于立刻执行(eager模式)。像PyTorch这样的库…

Java Web开发---复试Tips复习

(自用,摘录自各种文章和自己总结) 小知识点理解 Web Web应用开发主要是基于浏览器的应用程序开发。一个Web应用由多部分组成 Web应用程序编写完后,若想提供给外界访问,需要服务器来统一管理 常用的动态网页语言——…

react native中如何使用webView调用腾讯地图选点组件

react native中如何使用webView调用腾讯地图选点组件 效果示例图代码示例备注 效果示例图 代码示例 import React, {useEffect, useRef, useState} from react; import {Modal, StyleSheet} from react-native; import {pxToPd} from ../../common/js/device; import {WebView…

私有化部署自己的ChatGPT,免费开源的chatgpt-next-web搭建

随着AI的应用变广,各类AI程序已逐渐普及,尤其是在一些日常办公、学习等与撰写/翻译文稿密切相关的场景,大家都希望找到一个适合自己的稳定可靠的ChatGPT软件来使用。 ChatGPT-Next-Web就是一个很好的选择。它是一个Github上超人气的免费开源…

产品介绍二维码怎么做?多种内容组合二维码的方法

现在扫描二维码来获取内容的方式越来越常见,比如很多的产品介绍都会做成二维码图片后,在产品包装、传单、展板等印刷展示。而一般展示的内容类型多为文本、图片、视频等内容,那么这些类型的内容放入一个二维码中展示如何实现呢? …

白酒:制曲工艺的环境因素与微生物生态关系

在豪迈白酒的酿造过程中,制曲工艺是非常关键的一环。而环境因素与微生物生态关系对于制曲工艺的成功与否起着决定性的作用。云仓酒庄深谙此道,在制曲过程中注重环境因素的调控,并深入研究微生物生态关系,以提升豪迈白酒的品质和风…

Jmeter 命令启动 —— 动态参数化!

Jmeter命令行参数 1、在Linux中,使用非GUI的方式执行Jmeter。若需更改参数,必须先编辑jmx文件,找到对应变量进行修改,比较麻烦。 因此,可以参数化一些常用的变量,直接在Jmeter命令行进行设置 2、参数 -J…

draw.io设置矩形四个边的有无

第一步创建一个矩形 选中矩形,并编辑样式 然后在编辑框中输入 verticalLabelPositionbottom;verticalAligntop;html1;shapemxgraph.basic.rect;right1;将原来的内容覆盖掉 然后点击应用 然后发现 点击那四个设置就可以了