C#中字符串插值($) 和 逐字字符串(@)的使用
這段代碼使用了 C# 的 字符串插值($) 和 逐字字符串(@) 功能,并在 SQL 語(yǔ)句中動(dòng)態(tài)拼接變量。下面詳細(xì)解釋它們的用法:
1.$(字符串插值)
$ 是 C# 的 字符串插值 符號(hào),允許在字符串中直接嵌入表達(dá)式(用 {} 包裹),例如:
string name = "Alice";
string message = $"Hello, {name}!"; // 輸出:Hello, Alice!
在 SQL 語(yǔ)句中,$ 用于動(dòng)態(tài)插入變量值,如 {level}、{GetNextSortOrder(parentId)} 等。
2.@(逐字字符串)
@ 是 C# 的 逐字字符串 符號(hào),它會(huì):
- 忽略轉(zhuǎn)義字符(如
\n、\t等) - 允許字符串跨多行(適合 SQL 語(yǔ)句)
- 保留所有空格和換行
例如:
string sql = @"
SELECT *
FROM Users
WHERE Id = 1";
如果不加 @,換行符需要用 \n 表示,而加了 @ 后可以直接換行。
3.$@(同時(shí)使用)
$@ 結(jié)合了兩種功能:
- @ 允許 SQL 語(yǔ)句跨多行
- $ 允許在字符串中插入變量
所以:
string strsql = $@"
INSERT INTO System
(PID, Level, SortOrder, Name, remark, CreatedTime, ModifiedTime)
VALUES (...)
";
這樣既保持了 SQL 語(yǔ)句的可讀性,又能動(dòng)態(tài)插入變量。
4.{(level == 3 ? $"'{editForm.Target.Replace("'", "''")}'" : "NULL")}解釋
這段代碼是一個(gè) 嵌套的三元運(yùn)算符 + 字符串插值,用于動(dòng)態(tài)生成 SQL 語(yǔ)句中的 remark 字段值:
- level == 3:檢查當(dāng)前節(jié)點(diǎn)是否是第 3 級(jí)(可能是菜單項(xiàng))
- 如果是,則:
- editForm.remark.Replace("'", "''"):對(duì) remark 字符串進(jìn)行 SQL 轉(zhuǎn)義(單引號(hào) ' 替換成 '',防止 SQL 注入)
- $"'{...}'":用單引號(hào)包裹(因?yàn)?SQL 字符串需要用 ' 括起來(lái))
- 如果不是(level != 3),則直接插入 NULL(SQL 的 NULL 值,不加引號(hào))
- 如果是,則:
示例
假設(shè):
level = 3editForm.remark= "admin/home"
則生成的 SQL 部分:
remark= 'admin/home'
如果 level = 2,則:
remark= NULL
5. 完整 SQL 拼接示例
假設(shè):
- parentId = 1
- level = 3
- editForm.NodeName = "Admin Page"
- editForm.remark = "admin/home"
生成的 SQL 語(yǔ)句:
INSERT INTO System
(PID, Level, SortOrder, Name, remark, CreatedTime, ModifiedTime)
VALUES (
1,
3,
1, -- 假設(shè) GetNextSortOrder(parentId) 返回 1
'Admin Page',
'admin/home',
GETDATE(),
GETDATE()
)
6. 安全性注意事項(xiàng)
雖然這種拼接方式方便,但存在 SQL 注入風(fēng)險(xiǎn)(如果 NodeName、Target 等來(lái)自用戶輸入)。更安全的方式是使用 參數(shù)化查詢(如 SqlCommand.Parameters):
using (var cmd = new SqlCommand(
@"INSERT INTO System
(PID, Level, SortOrder, Name, remark, CreatedTime, ModifiedTime)
VALUES (@PID, @Level, @SortOrder, @Name, @remark, GETDATE(), GETDATE())",
connection))
{
cmd.Parameters.AddWithValue("@PID", parentId ?? (object)DBNull.Value);
cmd.Parameters.AddWithValue("@Level", level);
cmd.Parameters.AddWithValue("@SortOrder", GetNextSortOrder(parentId));
cmd.Parameters.AddWithValue("@Name", editForm.NodeName);
cmd.Parameters.AddWithValue("@remark", level == 3 ? editForm.Target : (object)DBNull.Value);
cmd.ExecuteNonQuery();
}
這樣可以有效防止 SQL 注入攻擊。
到此這篇關(guān)于C#中字符串插值($) 和 逐字字符串(@)的使用的文章就介紹到這了,更多相關(guān)C# 字符串插值 和 逐字字符串內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
c# in depth的泛型實(shí)現(xiàn)實(shí)例代碼
這篇文章主要介紹了c# in depth的泛型實(shí)現(xiàn)實(shí)例代碼,學(xué)C#的同學(xué)一定會(huì)用到泛型實(shí)現(xiàn)的,這里我們提供了泛型實(shí)現(xiàn)的程序代碼,大家參考使用2013-11-11
C#中科學(xué)繪圖庫(kù)ScottPlot的使用詳解
ScottPlot是基于.Net的一款開源免費(fèi)的交互式可視化庫(kù),支持Winform和WPF等UI框架,本文給大家介紹了C#中科學(xué)繪圖庫(kù)ScottPlot的使用方法,文中示例在WPF環(huán)境中運(yùn)行,需要的朋友可以參考下2023-12-12
WPF實(shí)現(xiàn)動(dòng)畫效果(三)之時(shí)間線(TimeLine)
這篇文章介紹了WPF實(shí)現(xiàn)動(dòng)畫效果之時(shí)間線(TimeLine),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
C#使用正則表達(dá)式實(shí)現(xiàn)首字母轉(zhuǎn)大寫的方法
這篇文章主要介紹了C#使用正則表達(dá)式實(shí)現(xiàn)首字母轉(zhuǎn)大寫的方法,涉及C#基于正則表達(dá)式操作字符串的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
c#使用簡(jiǎn)單工廠模式實(shí)現(xiàn)生成html文件的封裝類分享
這篇文章主要介紹了運(yùn)用了簡(jiǎn)單工廠模式實(shí)現(xiàn)頁(yè)面靜態(tài)化封裝類,思路比較簡(jiǎn)單,大家可根據(jù)自己的思路再擴(kuò)展此類2014-01-01
Unity實(shí)現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量
這篇文章主要為大家詳細(xì)介紹了Unity實(shí)現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01

