數(shù)據(jù)庫(kù)設(shè)計(jì) - 社交應(yīng)用的mysql表主鍵該怎么定義?
問(wèn)題描述
目前在設(shè)計(jì)一個(gè)移動(dòng)社交應(yīng)用,涉及的內(nèi)容有:用戶(hù)注冊(cè)、發(fā)布圖文分享、發(fā)表評(píng)論等等。
我已經(jīng)定義好相關(guān)的表及其主鍵,比如用戶(hù)信息表(USER_INFO-->USER_ID)、圖文分享表(SHARE_INFO-->SHARE_ID)、評(píng)論表(COMMENT_INFO-->COMMENT_ID),那么請(qǐng)教下這些表的主鍵我應(yīng)該怎么定義呢,是使用mysql的自增主鍵,還是程序自定義一套業(yè)務(wù)主鍵?
目前我的設(shè)計(jì)思路:自定義了一個(gè)表,存放每個(gè)數(shù)據(jù)表的表名和當(dāng)前的表的最大值(如表名:TABLE_MAX,字段:TABLE_NAME、MAX_VALUE),新增數(shù)據(jù)時(shí),為了防止并發(fā),使用存儲(chǔ)過(guò)程獲取下一個(gè)主鍵,然后數(shù)據(jù)表入庫(kù),但是這么做的話就使用到了數(shù)據(jù)庫(kù)的存儲(chǔ)過(guò)程的特性,感覺(jué)不是很好,代碼如下:
CREATE DEFINER=`root`@`localhost` PROCEDURE `generate_table_id`( in tn varchar(40), out cv int )BEGIN UPDATE table_id_generate SET CURRENT_VALUE = CURRENT_VALUE + 1 WHERE TABLE_NAME=tn; SELECT CURRENT_VALUE into cv from table_id_generate WHERE TABLE_NAME=tn;END
另外我看到的segmentfault的問(wèn)題的url是這樣的:https://segmentfault.com/q/10...,知乎的問(wèn)題url是這樣的:https://www.zhihu.com/questio...,其中的某個(gè)答案的url是:https://www.zhihu.com/questio...,這種url路徑,我相信應(yīng)該是restful風(fēng)格,那些數(shù)字應(yīng)該是相應(yīng)問(wèn)題或者回答的主鍵,請(qǐng)問(wèn)這種數(shù)字類(lèi)的主鍵是怎么生成的?數(shù)據(jù)庫(kù)是用varchar還是int,像sf這么長(zhǎng)的估計(jì)還不能用int。
請(qǐng)高手指教,謝謝!
問(wèn)題解答
回答1:其實(shí)不應(yīng)該自己去維護(hù)一套類(lèi)似自增字段的邏輯,sf這個(gè)應(yīng)該是在自增id的基礎(chǔ)上加了一個(gè)前綴,其實(shí)沒(méi)有多大必要,我理解的好的url規(guī)范應(yīng)該是通俗易懂的,這是我們家的url,盡可能使用自增id做主鍵,能用整型的不要用字符型,字符型會(huì)減慢查詢(xún)速度增大存儲(chǔ)空間
回答2:自增ID以后不好分表不好水平擴(kuò)展。
回答3:mysql主鍵最好不用字符型,字符型會(huì)導(dǎo)致頁(yè)斷裂,不是順序?qū)懀绊懶阅懿煌臉I(yè)務(wù)設(shè)計(jì)不同的主鍵生成規(guī)則比如說(shuō)帖子分類(lèi)表,頂多幾十個(gè)直接用mysql自增;又比如說(shuō)帖子表,在可以預(yù)見(jiàn)的將來(lái)可能會(huì)增加得很快,以后會(huì)設(shè)計(jì)到分表,分庫(kù)等,這種業(yè)務(wù)最好程序維護(hù)主鍵生成不要用自增
相關(guān)文章:
1. mysql - 這條聯(lián)合sql語(yǔ)句哪里錯(cuò)了2. webpack - vuejs+java前后臺(tái)分離實(shí)現(xiàn)及部署問(wèn)題3. 使用uuid,并不能利用mysql的索引,有什么解決辦法?4. 網(wǎng)站在移動(dòng)的環(huán)境下手機(jī),pc打不開(kāi)5. php - TP5的登錄驗(yàn)證問(wèn)題6. mysql - 我的myeclipse一直連顯示數(shù)據(jù)庫(kù)連接失敗,不知道為什么7. javascript - 微信小程序picker為什么會(huì)變成兩行?8. javascript - 微信h5發(fā)送圖文信息,部分設(shè)備點(diǎn)擊“發(fā)送”按鈕時(shí)沒(méi)反應(yīng),問(wèn)題較難重現(xiàn),如何能找到可能存在問(wèn)題的點(diǎn)?9. linux pdo 安裝配置中 make 遇到問(wèn)題,請(qǐng)大家指教!10. 在html文件的目錄下輸入代碼按回車(chē)后顯示這個(gè),哪位大佬幫幫我 呀
