Example Of has_many In Rails's ActiveRecord

一个简单的ActiveRecord中的has_many的示例,数据库中的表的建立SQL语句为:

create table items (
id int not null auto_increment,
title varchar(50) not null,
primary key (id)
);

create table users (
id int not null auto_increment,
name varchar(50) not null,
primary key (id)
);

create table items_users (
item_id int not null,
user_id int not null,
read_time date,
constraint fk_cp_item foreign key (item_id) references items(id),
constraint fk_cp_user foreign key (user_id) references users(id),
primary key (item_id, user_id)
);

 

执行后结果为:

#"Thinking in JAVA", "id"=>"1"}>
#"Tom", "id"=>"1"}>
----------------------------------------
[#"Thinking in JAVA", "id"=>"1"}>]
[#"Tom", "id"=>"1"}>]
----------------------------------------
2007-06-20
2007-06-20

require  " rubygems "
require 
" active_record "
require 
" pp "

ActiveRecord::Base.establish_connection(
    :adapter 
=>   " mysql " ,
    :host 
=>   " localhost " ,
    :database 
=>   " book2 " ,
    :username 
=>   " root " ,
    :password 
=>   "" ,
    :port 
=>   3306
)

class  Item  <  ActiveRecord::Base
    has_many :items_users, :dependent 
=>  :destroy
    has_many :users, :through 
=>  :items_users
end


Item.create([
    {:title 
=>   " Thinking in JAVA " },
    {:title 
=>   " Ruby on Rails Routing " },
    {:title 
=>   " Agible Development with Rails " }
])


class  ItemsUser  <  ActiveRecord::Base
    belongs_to :item
    belongs_to :user
end

class  User  <  ActiveRecord::Base
    has_many :items_users, :dependent 
=>  :destroy
    has_many :items, :through 
=>  :items_users
    
    
def  read_item(item)
        ItemsUser.create(:item 
=>  item,:user  =>  self,:read_time  =>  Date.today)
    end
end


User.create([
    {:name 
=>   " Tom " },
    {:name 
=>   " Mary " },
    {:name 
=>   " Jane " }
])


pp item 
=  Item.find(:first)
pp user 
=  User.find(:first)
puts 
" ---------------------------------------- "
user.read_item(item)
pp user.items
pp item.users
puts 
" ---------------------------------------- "
puts user.items_users.find(:first).read_time
puts item.items_users.find(:first).read_time

 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值