C#中字符串插值($) 和 逐字字符串(@)的使用
這段代碼使用了 C# 的 字符串插值($) 和 逐字字符串(@) 功能,并在 SQL 語句中動態(tài)拼接變量。下面詳細(xì)解釋它們的用法:
1.$(字符串插值)
$ 是 C# 的 字符串插值 符號,允許在字符串中直接嵌入表達(dá)式(用 {} 包裹),例如:
string name = "Alice";
string message = $"Hello, {name}!"; // 輸出:Hello, Alice!
在 SQL 語句中,$ 用于動態(tài)插入變量值,如 {level}、{GetNextSortOrder(parentId)} 等。
2.@(逐字字符串)
@ 是 C# 的 逐字字符串 符號,它會:
- 忽略轉(zhuǎn)義字符(如
\n、\t等) - 允許字符串跨多行(適合 SQL 語句)
- 保留所有空格和換行
例如:
string sql = @"
SELECT *
FROM Users
WHERE Id = 1";
如果不加 @,換行符需要用 \n 表示,而加了 @ 后可以直接換行。
3.$@(同時使用)
$@ 結(jié)合了兩種功能:
- @ 允許 SQL 語句跨多行
- $ 允許在字符串中插入變量
所以:
string strsql = $@"
INSERT INTO System
(PID, Level, SortOrder, Name, remark, CreatedTime, ModifiedTime)
VALUES (...)
";
這樣既保持了 SQL 語句的可讀性,又能動態(tài)插入變量。
4.{(level == 3 ? $"'{editForm.Target.Replace("'", "''")}'" : "NULL")}解釋
這段代碼是一個 嵌套的三元運算符 + 字符串插值,用于動態(tài)生成 SQL 語句中的 remark 字段值:
- level == 3:檢查當(dāng)前節(jié)點是否是第 3 級(可能是菜單項)
- 如果是,則:
- editForm.remark.Replace("'", "''"):對 remark 字符串進行 SQL 轉(zhuǎn)義(單引號 ' 替換成 '',防止 SQL 注入)
- $"'{...}'":用單引號包裹(因為 SQL 字符串需要用 ' 括起來)
- 如果不是(level != 3),則直接插入 NULL(SQL 的 NULL 值,不加引號)
- 如果是,則:
示例
假設(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 語句:
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. 安全性注意事項
雖然這種拼接方式方便,但存在 SQL 注入風(fēng)險(如果 NodeName、Target 等來自用戶輸入)。更安全的方式是使用 參數(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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
WPF實現(xiàn)動畫效果(三)之時間線(TimeLine)
這篇文章介紹了WPF實現(xiàn)動畫效果之時間線(TimeLine),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
C#使用正則表達(dá)式實現(xiàn)首字母轉(zhuǎn)大寫的方法
這篇文章主要介紹了C#使用正則表達(dá)式實現(xiàn)首字母轉(zhuǎn)大寫的方法,涉及C#基于正則表達(dá)式操作字符串的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-11-11
c#使用簡單工廠模式實現(xiàn)生成html文件的封裝類分享
這篇文章主要介紹了運用了簡單工廠模式實現(xiàn)頁面靜態(tài)化封裝類,思路比較簡單,大家可根據(jù)自己的思路再擴展此類2014-01-01
Unity實現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量
這篇文章主要為大家詳細(xì)介紹了Unity實現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-01-01

