Example Of has_many In Rails's ActiveRecord

本文通过一个具体的示例展示了如何使用ActiveRecord实现has_many及belongs_to关联。包括创建数据库表、定义模型之间的关联关系以及如何操作这些关联。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一个简单的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

 

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值