知乎專欄 | 多維度架構 | 微信號 netkiller-ebook | QQ群:128659835 請註明“讀者” |
用戶帳號或通行證系統設計,下面以我的數庫為例講解。
我一般使用兩個表 passport,profile 完成網站會員系統。
首先說說passport表,你也要以使用user或member等等命名,這個表設計儘可能地簡單,不要使用過多欄位。僅保存登錄所必須用到的欄位,如user,password,nickname,email... 登錄帳號和密碼做復合索引。
然後是profile表,這個表與passport是1:1關係,保存用戶詳細信息
這樣設計可以保證海量用戶登錄時的速度。
+----------+ | user | |----------| |id | <---+ |user | | |passwd | | |nickname | | |status | | +----------+ | 1:1 +----------+ | | profile | | |----------| | |user_id | o---+ |name | |sex | |address | |telphone | |status | +----------+
該表的功能是,防止用戶註冊過程中流逝,記錄已經填寫的數據。
CREATE TABLE `signup_keyloggers` ( `id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '唯一ID', `cookie` VARCHAR(32) NOT NULL COMMENT 'cookie id', `type` ENUM('baidu','google') NOT NULL COMMENT '推廣賬號類型', `field` ENUM('Name','Mobile','Email') NOT NULL COMMENT '欄位名', `value` VARCHAR(50) NOT NULL COMMENT '值', `status` ENUM('New','Sent','Ignored','Called','Processed') NOT NULL DEFAULT 'New' COMMENT '狀態', `operator` VARCHAR(10) NOT NULL COMMENT '操作人', `ctime` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '創建時間', `mtime` TIMESTAMP NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '狀態修改時間', PRIMARY KEY (`id`), UNIQUE INDEX `unique_index` (`type`, `cookie`, `field`, `value`) ) COMMENT='用戶註冊鍵盤記錄器' COLLATE='utf8_general_ci' ENGINE=InnoDB;
當用戶註冊成功會根據cookie id 刪除該表中的數據。
當數據被記錄後,客服就可以對客戶回訪,並修改狀態status,忽略 Ignored,郵件發送Sent, 電話回訪Called等等