C# 格式化SQL语句

在 C# 应用程序中,处理 SQL 语句是常见的任务,尤其是在数据访问和数据库操作中。格式化 SQL 语句不仅可以提高代码的可读性,还可以帮助开发者更容易地维护和调试代码。本文将介绍几种在 C# 中格式化 SQL 语句的方法,并提供实例代码。

1. 为什么要格式化 SQL 语句

格式化 SQL 语句有以下几个好处:

  • 提高可读性:格式化的 SQL 语句更易于阅读和理解。

  • 便于维护:整洁的代码更容易维护和更新。

  • 减少错误:清晰的格式有助于减少语法错误和逻辑错误。

  • 统一风格:团队中统一的代码风格有助于提高协作效率。

2. 手动格式化 SQL 语句

最简单的格式化方法是手动编辑 SQL 语句,使其具有良好的缩进和空格。

示例代码

 
 

csharp

string sql = @"
SELECT EmployeeID, FirstName, LastName
FROM Employees
WHERE DepartmentID = @DepartmentId
ORDER BY LastName, FirstName";

3. 使用字符串构建器

在 C# 中,可以使用 StringBuilder 类来构建和格式化 SQL 语句。

示例代码

 
 

csharp

var sqlBuilder = new StringBuilder();
sqlBuilder.AppendLine("SELECT EmployeeID, FirstName, LastName");
sqlBuilder.AppendLine("FROM Employees");
sqlBuilder.AppendLine("WHERE DepartmentID = @DepartmentId");
sqlBuilder.AppendLine("ORDER BY LastName, FirstName");

string sql = sqlBuilder.ToString();

4. 使用字符串插值和格式化

C# 6.0 引入了字符串插值,这使得嵌入变量和表达式到字符串中变得非常简单。

示例代码

 
 

csharp

int departmentId = 5;
string sql = $@"
SELECT EmployeeID, FirstName, LastName
FROM Employees
WHERE DepartmentID = {departmentId}
ORDER BY LastName, FirstName";

5. 使用参数化查询

为了防止 SQL 注入,建议使用参数化查询。这可以通过 SqlCommand 对象来实现。

示例代码

 
 

csharp

string sql = @"
SELECT EmployeeID, FirstName, LastName
FROM Employees
WHERE DepartmentID = @DepartmentId
ORDER BY LastName, FirstName";

using (SqlConnection connection = new SqlConnection(connectionString))
{
    SqlCommand command = new SqlCommand(sql, connection);
    command.Parameters.AddWithValue("@DepartmentId", departmentId);

    connection.Open();
    SqlDataReader reader = command.ExecuteReader();
    while (reader.Read())
    {
        Console.WriteLine($"{reader["EmployeeID"]} {reader["FirstName"]} {reader["LastName"]}");
    }
}

6. 使用 ORM 工具

对象关系映射(ORM)工具如 Entity Framework 可以自动生成格式化的 SQL 语句。

示例代码

 
 

csharp

using (var context = new MyDbContext())
{
    var query = context.Employees
        .Where(e => e.DepartmentID == departmentId)
        .OrderBy(e => e.LastName)
        .ThenBy(e => e.FirstName)
        .Select(e => new { e.EmployeeID, e.FirstName, e.LastName });

    foreach (var employee in query)
    {
        Console.WriteLine($"{employee.EmployeeID} {employee.FirstName} {employee.LastName}");
    }
}

7. 使用 SQL 格式化工具

有许多第三方工具和服务可以帮助格式化 SQL 语句,例如 SQL Server Management Studio (SSMS)、dbForge Studio for SQL Server、SQL Format 等。

示例

在 SSMS 中,你可以使用快捷键 Ctrl+Shift+F 来格式化 SQL 语句。

8. 编写自定义格式化程序

如果你有特定的格式化需求,可以编写自定义的格式化程序。

示例代码

 
 

csharp

public static string FormatSql(string sql)
{
    var lines = sql.Split(new[] { Environment.NewLine }, StringSplitOptions.None);
    var formattedLines = new List<string>();
    var indentLevel = 0;

    foreach (var line in lines)
    {
        string trimmedLine = line.TrimStart();
        if (trimmedLine.StartsWith("SELECT") || trimmedLine.StartsWith("UPDATE") || trimmedLine.StartsWith("DELETE") || trimmedLine.StartsWith("INSERT"))
        {
            indentLevel = 0;
        }

        var indent = new String(' ', 4 * indentLevel);
        formattedLines.Add(indent + trimmedLine);

        if (trimmedLine.StartsWith("FROM") || trimmedLine.StartsWith("JOIN") || trimmedLine.StartsWith("WHERE"))
        {
            indentLevel++;
        }
    }

    return String.Join(Environment.NewLine, formattedLines);
}

结论

格式化 SQL 语句是提高代码质量和维护性的重要步骤。无论是手动格式化、使用字符串构建器、参数化查询、ORM 工具还是自定义格式化程序,都有其适用场景。选择合适的方法可以显著提高你的工作效率和代码质量。

往期精品推荐:

在国内默默无闻的.NET,在国外火的超乎想象?

C#的膨胀之路:创新还是灭亡

介绍.NET 6款好看的winform开源UI库

介绍一款最受欢迎的.NET 开源UI库

WPF第三方开源UI框架:打造独特体验的魔法师

WPF与Winform,你的选择是?

WinForm的前世今生

.NET成年了,然后呢?——编程界的逆袭传奇

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

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

相关文章

gbase8s之建表相关问题

第一章..绪论 1.1..背景 需要对明年所有系统的表新建。 1.2..要求 对导切建表可能遇到的一些问题罗列及解决办法。 第二章..新建表的的过程 1.1..获取DDL 获取DDL一定要在服务器上去获取&#xff0c;千万别用gds去导出ddl。 1.1.1..切换数据库用户 su – gbasedbt 1.1…

HTTP vs WebSocket

本文将对比介绍HTTP 和 WebSocket &#xff01; 相关文章&#xff1a; 1.HTTP 详解 2.WebSocket 详解 一、HTTP&#xff1a;请求/响应的主流协议 HTTP&#xff08;超文本传输协议&#xff09;是用于发送和接收网页数据的标准协议。它最早于1991年由Tim Berners-Lee提出来&…

如何查看GB28181流媒体平台LiveGBS中对GB28181实时视频数据统计的负载信息

目录 1、负载信息2、负载信息说明3、会话列表查看 3.1、会话列表4、停止会话5、搭建GB28181视频直播平台 1、负载信息 实时展示直播、回放、播放、录像、H265、级联等使用数目 2、负载信息说明 直播&#xff1a;当前推流到平台的实时视频数目回放&#xff1a;当前推流到平台的回…

OpenAI Canvas最新发布,编程和写作迎来全新史诗级加强!

文章目录 零、前言一、GPT-40 with canvas操作指导写作领域加强建议编辑调整长度阅读水平添加最后的润色添加表情 编程领域加强选中代码问问题添加评论&#xff08;添加注释&#xff09;添加日志转换语言代码审查 二、感受 零、前言 最新消息&#xff0c;国庆期间OpenAI有大动…

解放双手-Mac电脑自定义文件默认打开方式的最有效方法

你们使用Mac的过程中&#xff0c;文件格式是不是每次都要自己选择打开方式&#xff0c;文件类型太多了&#xff0c;默认打开方式没办法兼顾所有的文件类型&#xff0c;这样太麻烦了&#xff0c;如果收到了新文件类型的文件&#xff0c;每次都要弹窗选择打开方式会不会心累 试试…

QT工程概述

在Qt中&#xff0c;创建 "MainWindow" 与 "Widget" 项目的主要区别在于他们的用途和功能范围&#xff1a; MainWindow&#xff1a;这是一个包含完整菜单栏、工具栏和状态栏的主窗口应用程序框架。它适合于更复 杂的应用程序&#xff0c;需要这些额外的用户…

git删除错误的commit

文章目录 1、git删除错误的commit2、.gitignore配置文件不生效的问题 1、git删除错误的commit git的流程如图&#xff1a; 当某次失误造成commit的版本有问题&#xff0c;需要回退到正常的版本修改后重新add。 首先通过git log查看commit提交记录&#xff0c;可以看到HEAD-…

使用Pytorch写简单线性回归

文章目录 Pytorch一、Pytorch 介绍二、概念三、应用于简单线性回归 1.代码框架2.引用3.继续模型(1)要定义一个模型&#xff0c;需要继承nn.Module&#xff1a;(2)如果函数的参数不具体指定&#xff0c;那么就需要在__init__函数中添加未指定的变量&#xff1a; 2.定义数据3.实例…

Redis哨兵模式部署(超详细)

哨兵模式特点 主从模式的弊端就是不具备高可用性&#xff0c;当master挂掉以后&#xff0c;Redis将不能再对外提供写入操作&#xff0c;因此sentinel模式应运而生。sentinel中文含义为哨兵&#xff0c;顾名思义&#xff0c;它的作用就是监控redis集群的运行状况&#xff0c;此…

如何利用phpstudy创建mysql数据库

phpStudy诞生于2007年&#xff0c;是一款老牌知名的PHP开发集成环境工具&#xff0c;产品历经多次迭代升级&#xff0c;目前有phpStudy经典版、phpStudy V8&#xff08;2019版&#xff09;等等&#xff0c;利用phpstudy可以快速搭建一个mysql环境&#xff0c;接下来我们就开始吧…

Unity MVC框架1-2 实战分析

该课程资源来源于唐老狮&#xff0c;吃水不忘打井人&#xff0c;不胜感激 Unity MVC框架演示 1-1 理论分析-CSDN博客 首先你需要知道什么mvc框架&#xff0c;并且对三个层级有个比较清晰的认识&#xff0c;当然不清楚也好&#xff0c;下面例子中将会十分细心地让你理解&#x…

SpringBoot在高校竞赛平台开发中的优化策略

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理高校学科竞赛平台的相关信息成为必然。开发…

TensorFlow详细配置

Anaconda 的安装路径配置系统环境变量 1 windows path配置 2 conda info C:\Users\Administrator>conda info active environment : None user config file : C:\Users\Administrator\.condarc populated config files : C:\Users\Administrator\.condarc …

Vue3中常用的八种组件通信方式

一、props父组件向子组件通信 父组件&#xff1a; props用于父组件向子组件传递数据&#xff0c;子组件用defineprops接收父组件传来的参数 在父组件中使用子组件时&#xff0c;给子组件以添加属性的方式传值 <sonCom car"宝马车"></sonCom> 其中如…

如何在 Jupyter Notebook 执行和学习 SQL 语句(上)—— 基本原理详解和相关库安装篇

近期我找工作很多岗位问到sql&#xff0c;由于我简历上有写&#xff0c;加上我实习的时候确实运用了&#xff0c;所以我还是准备复习一下SQL语句&#xff0c;常见的内容&#xff0c;主要包括一些内容&#xff0c;比如SQL基础&#xff08;主要是取数select&#xff0c;毕竟用的时…

electron-vite打包踩坑记录

electron-vite打包踩坑记录 大前端已成趋势&#xff0c;用electron开发桌面端应用越来越普遍 近期尝试用electronvite开发了个桌面应用&#xff0c;electron-vite地址&#xff0c;可用使用vue开发&#xff0c;vite打包&#xff0c;这样就很方便了 但是&#xff0c;我尝试了一…

Java项目实战II基于Java+Spring Boot+MySQL的桂林旅游景点导游平台(源码+数据库+文档)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者 一、前言 桂林&#xff0c;以其独特的喀斯特地貌、秀美的自然风光闻名遐迩&#xff0c;每年吸引着无数国内外游…

N1从安卓盒子刷成armbian

Release Armbian_noble_save_2024.10 ophub/amlogic-s9xxx-armbian (github.com) armbian下载&#xff0c;这里要选择905d adb 下载地址 https://dl.google.com/android/repository/platform-tools-latest-windows.zip 提示信息 恩山无线论坛 使用usb image tool restet a…

月饼市场新风潮:解析茶味的消费趋势

茶味月饼评论分析 一、评论的基本统计分析(数据来源&#xff1a;淘宝评论信息接口) 评论长度分布图&#xff1a; 根据接口拉取数据获得的评论数据&#xff0c;并进行数据清洗后&#xff0c;得到的评论如下&#xff1a; 评论总数: 9**3 评论长度描述性统计&#xff1a; Cou…

【GT240X】【3】Wmware17和Centos 8 安装

文章目录 一、说明二、安装WMware2.1 下载WMware2.2 安装2.3 虚拟机的逻辑结构 三、安装Centos3.1 获取最新版本Centos3.2 创建虚拟机 四、问题和简答4.1 centos被淘汰了吗&#xff1f;4.2 centos里面中文显示成小方块的解决方法4.3 汉语-英语输入切换4.4 全屏和半屏切换 五、练…