文章詳情頁
如何防止 MySQL 中純數(shù)字數(shù)據(jù)的 Insert?
瀏覽:146日期:2022-06-21 16:44:42
問題描述
比如我不希望 username 是純數(shù)字的,如果程序 insert 的數(shù)據(jù),username 是純數(shù)字的,就返回 mysql 數(shù)據(jù)格式錯誤,有這種功能嗎?
問題解答
回答1:通過儲存過程或者觸發(fā)器來實現(xiàn),但是這種邏輯最好還是由代碼層來控制
回答2:先說結論: 贊同LS的觀點,一般會寫在程序里面做驗證,數(shù)據(jù)庫只做基礎的比如unique這些的約束
如果真的要在數(shù)據(jù)庫做的話,一般會寫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:程序邏輯問題都不應該交給數(shù)據(jù)庫去處理,或者應該把它作為最后的驗證防線。
回答4:在提交前或者提交時就檢測。
回答5:這種基礎驗證也放在數(shù)據(jù)庫里來做,這不是給數(shù)據(jù)庫徒增壓力么?大家都在給它減負
相關文章:
1. 跟著課件一模一樣的操作使用tp6,出現(xiàn)了錯誤2. PHP類屬性聲明?3. angular.js - 這是什么錯?誰遇到過?給點提示4. transform - css3 translate 的水平垂直居中問題求解5. angular.js - angular里的ui-view里,獲取當前頁面的狀態(tài)參數(shù)用$state.params,在vue里類似的語法是什么呢?6. javascript - 安裝了babel,不起作用7. vue.js - nginx怎么修改跨域配置?8. css - div外層有一圈白色9. node.js - 初次安裝vue-cli遇到的問題10. 前端 - 應該先從angularJS , vue.js , react 這些框架中的哪個開始入手?
排行榜

熱門標簽