PHP防止使用者名稱重複(MD.13)
阿新 • • 發佈:2018-12-17
正在為了建立漫島而學習PHP,今天在做引導使用者填寫自己暱稱的時候,需要保證使用者暱稱不會重複,講訴如何避免使用者暱稱的重複即是此文的目的。具體步驟如下:
1.在建立資料庫表的時候,對使用者暱稱nickname
(下文均以此名代表使用者暱稱欄位)設定欄位唯一性。這樣後續寫入相同nickname
操作時,就會寫入失敗。
CREATE TABLE `t_user` (
`Id` int(11) NOT NULL AUTO_INCREMENT,
`nickname` varchar(18) NOT NULL unique,
PRIMARY KEY (`Id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
2.如果是建表後發現此需求,則執行如下程式碼即可為nickname
欄位設定唯一性。
ALTER TABLE `user` ADD unique(`nickname`);
3.用前端傳入的nickname
作為查詢條件查詢資料庫,看是否能查詢出結果,如果可以的話就說明有重複了,只是我擔心第三種方法在資料庫比較大的時候會有效能問題。
//使用tp框架的程式碼片段
if(isset($_POST['nickname']))
{
$result=Db::table('user')->field('id')->where('nickname' ,'夏爾')->find();
return empty($result)?'該暱稱可以使用':'該暱稱已被註冊';
}
以上就是我知道的關於防止使用者暱稱重複的一些手段了,實際我採用的具體方法是當用戶提交他的使用者暱稱時,我就去查資料庫,如果發現有重複,我就返回給前端方便前端及時提示使用者,當然我也把暱稱欄位設定為唯一性欄位了,多重保障!