亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#中字符串插值($) 和 逐字字符串(@)的使用

 更新時(shí)間:2025年11月04日 10:29:49   作者:愛吃巧克力的程序媛  
這篇文章主要介紹了C#中字符串插值($) 和 逐字字符串(@)的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

這段代碼使用了 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 = 3
  • editForm.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í)例代碼

    這篇文章主要介紹了c# in depth的泛型實(shí)現(xiàn)實(shí)例代碼,學(xué)C#的同學(xué)一定會(huì)用到泛型實(shí)現(xiàn)的,這里我們提供了泛型實(shí)現(xiàn)的程序代碼,大家參考使用
    2013-11-11
  • C#的winform如何嵌套另一個(gè)exe程序

    C#的winform如何嵌套另一個(gè)exe程序

    這篇文章主要介紹了C#的winform如何嵌套另一個(gè)exe程序問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • c#字符串去掉空格的二種方法(去掉兩端空格)

    c#字符串去掉空格的二種方法(去掉兩端空格)

    本文主要介紹了字符串去掉兩端空格,并且將字符串中多個(gè)空格替換成一個(gè)空格的方法,需要的朋友可以參考下
    2014-02-02
  • C#多線程之任務(wù)的用法詳解

    C#多線程之任務(wù)的用法詳解

    本文詳細(xì)講解了C#多線程之任務(wù)的用法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • C#中科學(xué)繪圖庫(kù)ScottPlot的使用詳解

    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)

    這篇文章介紹了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á)式實(shí)現(xiàn)首字母轉(zhuǎn)大寫的方法,涉及C#基于正則表達(dá)式操作字符串的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-11-11
  • c#使用簡(jiǎn)單工廠模式實(shí)現(xiàn)生成html文件的封裝類分享

    c#使用簡(jiǎn)單工廠模式實(shí)現(xiàn)生成html文件的封裝類分享

    這篇文章主要介紹了運(yùn)用了簡(jiǎn)單工廠模式實(shí)現(xiàn)頁(yè)面靜態(tài)化封裝類,思路比較簡(jiǎn)單,大家可根據(jù)自己的思路再擴(kuò)展此類
    2014-01-01
  • 基于C#實(shí)現(xiàn)文檔打印功能

    基于C#實(shí)現(xiàn)文檔打印功能

    在軟件開發(fā)過(guò)程中,文檔打印是一個(gè)常見的功能需求,本文將詳細(xì)介紹如何在C#中實(shí)現(xiàn)文檔打印,并通過(guò)代碼示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定幫助,需要的朋友可以參考下
    2024-10-10
  • Unity實(shí)現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量

    Unity實(shí)現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量

    這篇文章主要為大家詳細(xì)介紹了Unity實(shí)現(xiàn)繞任意軸任意角度旋轉(zhuǎn)向量,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-01-01

最新評(píng)論