用户是网站的用户。 如果用户将在网站中创建页面,则创建页面的用户将成为该特定页面的拥有者。 用户可以向其他用户发送邀请以加入他的页面。 如果用户将加入其他用户的页面,则加入该页面的用户将成为该页面的访客。
所以请任何人帮我设计上述模型的数据库。
答案 0 :(得分:0)
将有三个模型用于用户,另一个用于用户创建的网站页面,第三个模型将存储访问页面的访客的详细信息。
以下是user,website_page和website_guest之间的高级描述。请在数据库中添加应用程序中所需的规范。
User
has_many :website_pages, dependent: :destroy
has_many :website_guest, through: :website_pages
Website_pages #user_id (will be the owner)
belongs_to :user
has_many: website_guests, dependent: :destroy
Website_Guests #website_id (will reference the website page) , guest_id
belongs_to :website_pages
belongs_to :user, foreign_key: :guest_id
希望它有所帮助!!
答案 1 :(得分:0)
您将拥有3个模型:User, Pages, Member
。迁移将如下:
# Generate the model User
be rails g model user email:string
# Generate the model Page
be rails g model page title:string user:references
# Generate the model Member
be rails g model member user:references page:references
class User < ApplicationRecord
has_many :pages, dependent: :destroy
has_many :members
has_many :memberships, through: :members, source: :page
end
class Page < ApplicationRecord
belongs_to :owner, class_name: 'User', foreign_key: 'user_id'
has_many :members, dependent: :destroy
has_many :guests, through: :members, source: :user
end
class Member < ApplicationRecord
belongs_to :user
belongs_to :page
end
您可以尝试在控制台中测试它:
user1 = User.create email: 'user1@test.com'
user2 = User.create email: 'user2@test.com'
user3 = User.create email: 'user3@test.com'
page1 = user1.pages.create title:'Page 1'
page1.members.create user:user2
page2 = user2.pages.create title:'Page 2'
page2.members.create user:user1
page2.members.create user:user3
page2.owner
#<User id: 2, email: "user2@test.com", created_at: "2018-05-20 11:03:10", updated_at: "2018-05-20 11:03:10">
page2.guests
#<ActiveRecord::Associations::CollectionProxy [#<User id: 1, email: "user1@test.com",..>, #<User id: 3, email: "user3@test.com",..]>
user2.memberships
#<ActiveRecord::Associations::CollectionProxy []>
我希望我能帮到你,他们采用不同的方法,很大程度上取决于你的业务逻辑和领域。 Rails非常灵活且文档齐全。我建议你检查: