久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

數(shù)據(jù)庫設(shè)計 - 社交應(yīng)用的mysql表主鍵該怎么定義?

瀏覽:129日期:2022-06-19 18:20:44

問題描述

目前在設(shè)計一個移動社交應(yīng)用,涉及的內(nèi)容有:用戶注冊、發(fā)布圖文分享、發(fā)表評論等等。

我已經(jīng)定義好相關(guān)的表及其主鍵,比如用戶信息表(USER_INFO-->USER_ID)、圖文分享表(SHARE_INFO-->SHARE_ID)、評論表(COMMENT_INFO-->COMMENT_ID),那么請教下這些表的主鍵我應(yīng)該怎么定義呢,是使用mysql的自增主鍵,還是程序自定義一套業(yè)務(wù)主鍵?

目前我的設(shè)計思路:自定義了一個表,存放每個數(shù)據(jù)表的表名和當前的表的最大值(如表名:TABLE_MAX,字段:TABLE_NAME、MAX_VALUE),新增數(shù)據(jù)時,為了防止并發(fā),使用存儲過程獲取下一個主鍵,然后數(shù)據(jù)表入庫,但是這么做的話就使用到了數(shù)據(jù)庫的存儲過程的特性,感覺不是很好,代碼如下:

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的問題的url是這樣的:https://segmentfault.com/q/10...,知乎的問題url是這樣的:https://www.zhihu.com/questio...,其中的某個答案的url是:https://www.zhihu.com/questio...,這種url路徑,我相信應(yīng)該是restful風格,那些數(shù)字應(yīng)該是相應(yīng)問題或者回答的主鍵,請問這種數(shù)字類的主鍵是怎么生成的?數(shù)據(jù)庫是用varchar還是int,像sf這么長的估計還不能用int。

請高手指教,謝謝!

問題解答

回答1:

其實不應(yīng)該自己去維護一套類似自增字段的邏輯,sf這個應(yīng)該是在自增id的基礎(chǔ)上加了一個前綴,其實沒有多大必要,我理解的好的url規(guī)范應(yīng)該是通俗易懂的,這是我們家的url,盡可能使用自增id做主鍵,能用整型的不要用字符型,字符型會減慢查詢速度增大存儲空間

回答2:

自增ID以后不好分表不好水平擴展。

回答3:

mysql主鍵最好不用字符型,字符型會導(dǎo)致頁斷裂,不是順序?qū)懀绊懶阅懿煌臉I(yè)務(wù)設(shè)計不同的主鍵生成規(guī)則比如說帖子分類表,頂多幾十個直接用mysql自增;又比如說帖子表,在可以預(yù)見的將來可能會增加得很快,以后會設(shè)計到分表,分庫等,這種業(yè)務(wù)最好程序維護主鍵生成不要用自增

相關(guān)文章:
主站蜘蛛池模板: 家居| 延长县| 黄石市| 东海县| 锦屏县| 吉木乃县| 彩票| 牟定县| 云龙县| 邹城市| 纳雍县| 长寿区| 凤阳县| 咸阳市| 普宁市| 寿阳县| 郸城县| 合水县| 阿拉善右旗| 嘉祥县| 隆安县| 青神县| 马边| 门头沟区| 东安县| 英山县| 泸水县| 昌都县| 阿图什市| 正蓝旗| 泊头市| 沙田区| 博乐市| 望谟县| 长葛市| 正蓝旗| 利川市| 望都县| 云龙县| 四平市| 彭州市|