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

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

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

    老妖的博客
    現實的中沒有幾個人能夠真為對方去死,甚至山盟海誓很快就會在金錢面前變的微不足道,這才是生活。沒有永遠的愛,除了你的父母對你,當然也就沒有永遠的恨,更沒有永遠的痛,時間是最好的治療大師,它會很快撫平你心靈上累累的傷痕。很多年以后你想起來時,那些在你生命中洶涌來往的人群至多是個模糊的影子或者毫無意義的名字
    posts - 105,  comments - 171,  trackbacks - 0

    作為java中的O/R Mapping的使用者來說,看到rails中的activeRecord的實現后不禁汗顏,原來O/R Mapping可以如此簡單。
    我反復看過幾遍activeRecord的文檔,覺得其靈活之處不亞于hibernate,而且簡單實用。
    現作筆錄如下:
    1.關聯
    n:1: belongs_to: XXXX
    1:n: has_many:XXX
    1:1: has_one :XXX
    m:n: has_and_belongs_to_many:XXX
    連接join: :through => :XXX (for ex:has_many :photos :through => :slides) rails 1.1才有此功能
    特殊關聯:
    acts_as_list :列表
    acts_as_tree :父子關系
    acts_as_nested_set

    class Slide < ActiveRecord::Base
    ? belongs_to :slideshow
    ? acts_as_list :scope => "slideshow_id"
    ? belongs_to :photo
    end
    表示sildes表中的slideshow_id為belongs_to :slideshow關系中的外鍵(FK)
    class Category < ActiveRecord::Base
    ? acts_as_tree
    end

    ?

    2.級聯
    has_many :XXX, dependent => true

    3.設定主鍵:rails不支持復合主鍵,rails默認數據表中的主鍵名稱為id,如果您的主鍵不為id,如下設置:
    class Photo < ActiveRecord::Base
    ? set_primary_key "created_at"
    end
    4.domain中的繼承關系
    class Photographer < Person
    end

    class Person < ActiveRecord::Base
    end
    5.domain中的組件關系
    CREATE TABLE people (
    ?? id INT AUTO_INCREMENT NOT NULL,
    ?? type VARCHAR(20),
    ?? name VARCHAR(20),
    ?? email VARCHAR(30),
    ?? street_address VARCHAR(30),
    ?? city VARCHAR(30),
    ?? state VARCHAR(20),
    ?? zip INTEGER(5),
    ?? camera VARCHAR(20),
    ?? PRIMARY KEY (id)
    );

    class Person < ActiveRecord::Base
    ? composed_of :address, :class_name => "Address",
    ????????????? :mapping => [[:street_address, :street_address],
    ?????????????????????????? [:city, :city],
    ?????????????????????????? [:state, :State],
    ?????????????????????????? [:zip, :zip]]
    end
    class Address
    ? def initialize(street_address, city, state, zip)
    ??? @street_address = street_address
    ??? @city = city
    ??? @state = state
    ??? @zip = zip
    ? end

    ? attr_reader :street_address, :city, :state, :zip
    end
    6.查找記錄
    find_by_<column_name> find_by_id
    find_by_<column_name>_and_<column_name> find_by_name_and_email(name, email)
    7.驗證字段有效性
    class Photo < ActiveRecord::Base
    ? validates_presence_of :filename 驗證是否為空
    end

    validates_format_of :email,
    ??????????????????? :with => /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i
    validates_length_of :name, :within => 6..100???????????????????
    8.事務處理
    def transfer(from, to, amount)
    ? Account.transaction do
    ??? from.debit(amount)
    ??? to.credit(amount)
    ? end
    end

    ?

    ?


    ?

    posted on 2006-09-14 15:55 老妖 閱讀(4962) 評論(0)  編輯  收藏 所屬分類: rails

    <2006年9月>
    272829303112
    3456789
    10111213141516
    17181920212223
    24252627282930
    1234567

    常用鏈接

    隨筆分類(48)

    隨筆檔案(104)

    好友鏈接

    我的豆瓣

    積分與排名

    • 積分 - 220769
    • 排名 - 257

    最新評論

    閱讀排行榜

    主站蜘蛛池模板: 一级特级女人18毛片免费视频| 亚洲大片免费观看| 国产一区二区三区亚洲综合 | 三级黄色片免费看| 亚洲性久久久影院| 亚洲免费视频一区二区三区| 亚洲婷婷国产精品电影人久久| 日韩在线视频免费| 久久精品夜色噜噜亚洲A∨| 一区二区三区免费视频观看| 国产性爱在线观看亚洲黄色一级片| 亚洲免费无码在线| 老司机亚洲精品影院| 成年黄网站色大免费全看| 亚洲中文字幕无码久久| 大胆亚洲人体视频| 99视频在线观看免费| 亚洲日韩区在线电影| 黄页网站免费观看| 国产AV无码专区亚洲AV琪琪| 亚洲人成网站色在线入口| 精品熟女少妇aⅴ免费久久 | 亚洲国产成人片在线观看| 热re99久久6国产精品免费| 亚洲另类图片另类电影| 国产精品久久香蕉免费播放| 2022免费国产精品福利在线| 亚洲91av视频| 全免费a级毛片免费看不卡| 久久久久久毛片免费看| 亚洲最大免费视频网| 免费观看日本污污ww网站一区| 国产免费黄色无码视频| 亚洲午夜成激人情在线影院| 国产大片线上免费看| 99久久免费看国产精品| 亚洲精品无码永久在线观看男男| 相泽亚洲一区中文字幕| 久久久久久国产a免费观看黄色大片 | 一级做a爱过程免费视| 亚洲国产精品乱码在线观看97|