0
A
回答
2
0
的選擇取決於:
- 號或記錄
- 該數據庫使用
- 關係與其它表
如號國家代碼將是一個重複列,它可以放在varchar類型列中,就像它是例如+ 91-9654637268。這將允許不同格式的電話號碼,但不能在數據庫級驗證輸入的值必須是您需要在代碼級別驗證的數字。使用varchar必須是存儲電話的首選號碼與他們的國家代碼,因爲它會避免加入更快。
但是,如果你需要大量的操作,使用一個bigint將存儲數字,例如, 9764536377443其中前兩位是國家代碼,其餘的數字是電話號碼部分。
或者你可以爲國家代碼單獨的列這將增加不必要的加入,但如果需要的國家代碼在幾個地方,必須很好的驗證和約束whihc也可以通過實現可幫助使用上述任何技術。
希望它有幫助。
0
事務數據庫
如果這是一個事務型數據庫(很多更新),或通用數據庫(查詢和更新),然後使用數據庫正常化喬納森說。因此,有一個叫國表結構
| ID | CountyCode | CountryName |
| 1 | +49 | Germany |
| 2 | +1 | USA |
這樣你就可以保持國家代碼和大約的電話號碼數據與它走描述信息。所以說一個國家改變其名稱或國家代碼,而不必更新電話號碼錶中的每個受影響的行,只需更新國家/地區表中的一行即可。
然後爲電話號碼的其餘部分(根據您是否想要分割區號等等))與列,作爲一個外鍵引用CountyCode ID
| ID | CountyCodeID | TelNumber |
| 1 | 1 | 12345 |
但是記住,這是用大量的數據(數據集市,數據倉庫做的事情,在查詢重的情況下的通用方式),那麼不同的方法最好看Star Schemas
相關問題
- 1. 保存電話號碼+國家代碼
- 2. 從包含國家代碼的號碼獲取電話號碼
- 3. 將電話號碼轉換爲國際國家代碼iOS
- 4. 從國家或國家代碼獲取電話代碼 - Twilio
- 5. 獲取給定電話號碼的詳細國家名稱和國家代碼
- 6. 電話號碼的國家列表
- 7. Validaiton電話號碼爲多個國家
- 8. 如何從給定的電話號碼獲得國家代碼
- 9. PHP - RegEx匹配電話號碼有或沒有國家代碼
- 10. 根據國家/地區代碼格式化電話號碼
- 11. 獲取設備的國家代碼/電話號碼
- 12. 獲取Android中沒有國家代碼的電話號碼
- 13. 從電話號碼查找國家代碼
- 14. 格式的電話號碼與國家代碼
- 15. 從電話號碼[libphonenumber]提取代碼國家
- 16. 正常化給定國家代碼的電話號碼
- 17. 正則表達式的電話號碼與國家代碼
- 18. 清單電話號碼的所有國家代碼
- 19. 根據國家代碼驗證電話號碼
- 20. 如何從電話號碼中刪除「+」和國家代碼?
- 21. 具有國家代碼和國旗的角度國際電話號碼
- 22. android撥入電話的國家代碼
- 23. 與javascript匹配電話國家代碼
- 24. 如何確定一個電話號碼(國家代碼)是否等於另一個(不包括國家代碼)
- 25. 拆分電話號碼(手機或座機)納入國家代碼,區號和電話號碼
- 26. 從python的國家代碼中獲取電話號碼的國際前綴
- 27. 從電話號碼確定國際電話代碼的算法
- 28. 在Angular 4中驗證電話號碼和國家代碼組合以獲取電話號碼驗證?
- 29. 國家電話代碼,包括地區代碼
- 30. 國際電話號碼