PHP防止用戶名重複(MD.13)

正在爲了創建漫島而學習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)?'該暱稱可以使用':'該暱稱已被註冊';         
}

以上就是我知道的關於防止用戶暱稱重複的一些手段了,實際我採用的具體方法是當用戶提交他的用戶暱稱時,我就去查數據庫,如果發現有重複,我就返回給前端方便前端及時提示用戶,當然我也把暱稱字段設置爲唯一性字段了,多重保障!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章