1. 程式人生 > >PHP防止使用者名稱重複(MD.13)

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)?'該暱稱可以使用':'該暱稱已被註冊'; }

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