文章詳情頁
如何防止 MySQL 中純數字數據的 Insert?
瀏覽:111日期:2022-06-21 16:44:42
問題描述
比如我不希望 username 是純數字的,如果程序 insert 的數據,username 是純數字的,就返回 mysql 數據格式錯誤,有這種功能嗎?
問題解答
回答1:通過儲存過程或者觸發器來實現,但是這種邏輯最好還是由代碼層來控制
回答2:先說結論: 贊同LS的觀點,一般會寫在程序里面做驗證,數據庫只做基礎的比如unique這些的約束
如果真的要在數據庫做的話,一般會寫trigger
然后貌似還有add constraint check,但是mysql里面即使支持這個東西,也不會在存儲之前做檢查(all engines)
http://stackoverflow.com/questions/16005283/is-it-possible-to-enforce-data-checking-in-mysql-using-regular-expression
回答3:程序邏輯問題都不應該交給數據庫去處理,或者應該把它作為最后的驗證防線。
回答4:在提交前或者提交時就檢測。
回答5:這種基礎驗證也放在數據庫里來做,這不是給數據庫徒增壓力么?大家都在給它減負
相關文章:
1. Python2中code.co_kwonlyargcount的等效寫法2. thinkPHP5中獲取數據庫數據后默認選中下拉框的值,傳遞到后臺消失不見。有圖有代碼,希望有人幫忙3. mysql主從 - 請教下mysql 主動-被動模式的雙主配置 和 主從配置在應用上有什么區別?4. 求救一下,用新版的phpstudy,數據庫過段時間會消失是什么情況?5. django - Python error: [Errno 99] Cannot assign requested address6. python小白 關于類里面的方法獲取變量失敗的問題7. mysql數據庫做關聯一般用id還是用戶名8. linux運維 - python遠程控制windows如何實現9. python小白,關于函數問題10. javascript - 如何用最快的速度C#或Python開發一個桌面應用程序來訪問我的網站?
排行榜
