以前一直沒有見過@出如今C#語句的字符串前的用法,此次去德瑞的面試題中第一次見到這種格式的,一會兒沒反應過來,而後回來找了些資料,才知道原來@在帶轉義字符的字符串前面能夠消除轉移字符的做用,因此今天雖然題作錯了,但也算是成長了。(如下內容摘自博客園)面試
1. 加在字符串前面,字符串中的 \ 失去轉義符的做用,直接寫字符串而不須要考慮轉義字符sql
- string path = @"C:\Windows\"; // 若是不加 @,編譯會提示沒法識別的轉義序列
- // 若是不加 @,能夠寫成以下
- string path2 = "C:\\Windows\\";
- string path = @"C:\Windows\"; // 若是不加 @,編譯會提示沒法識別的轉義序列
- // 若是不加 @,能夠寫成以下
- string path2 = "C:\\Windows\\";
2. 加在字符串前面,字符串中的 " 要用 "" 表示c#
- string str = @"aaa=""bbb""";
- // 不加 @,能夠寫成
- string str2 = "aaa=\"bbb\"";
- string str = @"aaa=""bbb""";
- // 不加 @,能夠寫成
- string str2 = "aaa=\"bbb\"";
3 加在字符串前面,換行空格都保存着,方便閱讀代碼ide
- string insert = @"
- insert into Users
- (
- UserID,
- Username,
- Email
- ) values
- (
- @UserID,
- @Username,
- @Email
- )";
- string insert = @"
- insert into Users
- (
- UserID,
- Username,
- Email
- ) values
- (
- @UserID,
- @Username,
- @Email
- )";
4 用關鍵字作變量時在關鍵字前面加@字符串
- string @operator = "+";
- string @class = "分類一";
- Console.WriteLine(@operator);
- Console.WriteLine(@class);
- string @operator = "+";
- string @class = "分類一";
- Console.WriteLine(@operator);
- Console.WriteLine(@class);
5 做爲sql語句裏的一個「標籤」,聲明此處須要插入一個參數博客
-
- string delete = "delete from Categery where CategoryID=@CategoryID";
- SqlConnection connection = new SqlConnection("connectionString");
- SqlCommand command = new SqlCommand(delete, connection);
- command.Parameters.Add("@CategoryID", SqlDbType.BigInt);