今天在遇到一個需求的時候,需要一個字元串實現自增。是根據資料庫中一個自增的int類型的值,實現自增的。但是要加上首碼。比如,資料庫中有一個自增的值,為,2。那麼這個自增的值後面的值就位3、4、5、6、7.....100、101、102......所以我要獲得 的這個字元串就要是"S0001"、"S0 ...
今天在遇到一個需求的時候,需要一個字元串實現自增。是根據資料庫中一個自增的int類型的值,實現自增的。但是要加上首碼。比如,資料庫中有一個自增的值,為,2。那麼這個自增的值後面的值就位3、4、5、6、7.....100、101、102......所以我要獲得 的這個字元串就要是"S0001"、"S0002"、"S0003"........"S0100"、"S0101"、"S0102"......
因為,這個"0"的數量還比較少,最一開始寫的一個方法:
public string GetSelfIncrStr() { var shopCode = "S"; var newID = 101; if (newID < 10) { shopCode += $"000{newID}"; } else if (newID < 100) { shopCode += $"00{newID}"; } else if (newID < 1000) { shopCode += $"0{newID}"; } else { shopCode += newID; } return shopCode; }
0的個數少,還可以這樣寫,如果有十個"0"或者更多的呢?這樣寫就不方便了。
幸好,C#中字元串有一個方法
public String PadLeft(int totalWidth, char paddingChar);
返回值:
返回一個新字元串,該字元串通過填充右對齊此實例中的字元。它們位於左側,具有指定的Unicode字元,具有指定的總長度。
參數:
totalWidth:結果字元串中的字元數,等於原始字元串的數目,字元加上任何其他填充字元。
paddingChar:Unicode填充字元。
所以,這個方法就可以改寫成如下:
public string GetSelfIncrStr() { var newID = 101; return "S" + newID.ToString().PadLeft(3, '0'); }
這樣寫起來就方便多了。
還有一個方法:
public String PadRight(int totalWidth);
static string GetStr() { var str = "100"; return str.PadRight(5, '0'); }
這個方法得到的結果是10000。
其實,這個任務,是根據資料庫中的int類型自增的值,來自增這個字元串的,這個自增的字元串還是表的主鍵。這個表不是我設計的,個人理解,這種場景還是儘量少的有吧,因為這樣的設計並不好。應該從資料庫表的設計和使用場景來設計。
不過這兩個方法還是蠻好用的。