一直有一個有關問題,基本,但是還是想弄清楚。mysql讀取資料庫儲存。鐺鐺鐺

來源:互聯網
上載者:User
一直有一個問題,基本,但是還是想弄清楚。mysql讀取資料庫儲存。。。鐺鐺鐺
本帖最後由 xianglei1130 於 2013-03-04 14:50:06 編輯

一直以來都有這個問題,今天比較亢奮,發個貼跟大家討論下。

自知自己技術一般,所以大蝦別噴。

就是假如有一個總記錄 A 表,裡面有各種欄位,sid title content link....

然後有一個個人記錄表 B 表 ,欄位:id name sid(A表的sid) 來記錄這個人所擁有的A表中的資料。

那現在問題出現了,假如B表”張三“有10條A表記錄,我是把 10個sid用一個符號組合在一起存入B表的sid呢。還是產生10條記錄存入B表呢?





考慮到往出取的時候 第1種方法自然是用explode 來分割B表sid,然後進行迴圈再查詢A表來取出資料。 第2種方法就是直接將該id的所有記錄查出迴圈出來。

那麼到底是哪種方法好? 從 資料庫 程式各方面所下。 在下不知道闡述的怎麼樣,還望指教。。。 資料庫 儲存 mysql


------解決方案--------------------
1、可以用一個符號(,)組合在一起存入B表的sid,查詢時 find_in_set(A.sid,B.sid)
這種情況要求B.sid足夠大,假如不是10條而是1000條,10000條呢
2、可以每個sid一條存入B,查詢時 A.sid=B.sid
看著很傻,但很有效
3、以上的方案都是假定A.sid是公有的,即多個使用者可以擁有同一個A.sid。比如:好友、關注
如果A.sid是使用者私人的,比如發帖
那就應該在A中增加一個uid欄位來記錄歸屬
------解決方案--------------------
第二種簡單,第explode的話,還要自己做很多操作
  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.