<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-167  評論-65  文章-0  trackbacks-0
    多態(tài)關(guān)聯(lián) 也叫虛擬關(guān)聯(lián), 其實 表是不存在的。。。不像 :through => :connections 那connections的表是存在的,也可以不存在的,connections是一個關(guān)聯(lián)模型

    有這樣一個需求,需要用到 虛擬關(guān)聯(lián)

    在SNS中,例如xiaonei,douban等等都有 最近好友更新的內(nèi)容顯示,那么這個 一般是在一個 表中,例如 叫activities 表,更新有很多種 ,例如 修改頭像,發(fā)表日志,建立了好友關(guān)系,發(fā)表評論等等,。。說白了就是 一個表 關(guān)聯(lián)了 多個表,那就得用到 虛擬 關(guān)聯(lián)了。。

    表結(jié)構(gòu):


    原理:
    上面有三個表,activities表(記錄更新了那些操作,最重要的兩個字段是item_id,和item_type,item_id是對應(yīng)到關(guān)聯(lián)表的主鍵id,item_type是對應(yīng)到關(guān)聯(lián)表的表對象名例如comments表就是Comment) Posts表 (用戶發(fā)表文字的表,例如有發(fā)表blog的blog_id,發(fā)表論壇 topic的 topic_id,給用戶留言的client_info_id,body是發(fā)表的內(nèi)容),
    comments表(評論表,body是評論內(nèi)容,當然評論也好好多種評論,這個表里也需要關(guān)聯(lián)許多表,從comments表的字段中也可以看到用了虛擬關(guān)聯(lián))

    用法:
    model:

    activity
    class Activity < ActiveRecord::Base
      ................
      belongs_to :item, :polymorphic => true
    ..........................
    end

    Comment
    ..................
    has_many :activities, :foreign_key => "item_id" , :dependent => :destroy
    ..................

    加上 :dependent => :destroy 是當這條評論刪除時,activities 表里的記錄同時被刪除


    或者:

    has_many :activities, :as => :item , :dependent => :destroy


    那么 Post 模型 同理可得。。。。

    因為上面的 :item , 所以 activities 表里的 item_id ,  item_type 是約定俗成的。。。。。。。。。

    取數(shù)據(jù)
     activity.item.body
    activity 是activities表中的記錄對象

    ref:
    http://guides.rails.info/association_basics.html
    http://hideto.javaeye.com/blog/76709
    http://hi.baidu.com/rainchen/blog/item/fc3a94eeb31ad62b2df53412.html
    http://iceskysl.1sters.com/?action=show&id=25
    http://rubycnrails.cn/articles/23 (了解:dependent=>:destroy)




    write by feng
    posted on 2009-08-12 17:06 fl1429 閱讀(2381) 評論(0)  編輯  收藏 所屬分類: Rails
    已訪問數(shù):
    free counters
    主站蜘蛛池模板: 精品国产免费观看| 亚洲视频免费播放| 亚洲国产一区视频| 免费人成再在线观看网站| 国产精品成人免费综合| 亚洲精品无码永久在线观看男男| 国内免费高清在线观看| 亚洲精品123区在线观看| 全免费a级毛片免费**视频| 亚洲av无码偷拍在线观看| 日本xxwwxxww在线视频免费| 18禁亚洲深夜福利人口| 亚洲AV无码专区日韩| 成人无码精品1区2区3区免费看| 亚洲另类激情综合偷自拍图| 久久久国产精品福利免费| 在线观看亚洲一区二区| 九九精品免费视频| 亚洲熟妇自偷自拍另欧美| 国产在线观看免费完整版中文版| 伊人久久国产免费观看视频| 亚洲国产精品白丝在线观看| 国产精品视频免费| 亚洲第一第二第三第四第五第六 | 亚洲中文字幕人成乱码| 午夜精品在线免费观看| 成人a毛片免费视频观看| 亚洲成A人片在线观看WWW| 中文字幕免费高清视频| 亚洲av成人无码网站…| 亚洲精品无码专区在线在线播放| 亚洲免费在线视频观看| 亚洲AV日韩AV无码污污网站 | 亚洲综合无码一区二区三区| 成人免费看吃奶视频网站| 精品多毛少妇人妻AV免费久久 | 亚洲av无码专区亚洲av不卡| 国产亚洲人成网站在线观看| 日本高清在线免费| 一个人看的www免费在线视频| 亚洲综合图片小说区热久久|