我正在开发一个padrino Web应用程序。我有两张桌子:
User
表:包含id
,name
,address
字段Post
表:id
,user_id
,content
如果我加入他们,
User.join(:posts, user_id:, :id)
他们返回两个名称相同的字段id
:
id name address id user_id content
1 jim *** 3 1 post1
我想重命名这些id
中的每一个。我希望结果是:
u_id name address p_id user_id content
1 jim *** 3 1 post1
我在padrino项目中使用sequel适配器用于postgresql db。 在mysql查询中,它将是这样的:
select u.id as u_id,
u.name,
u.address,
p.id as p_id,
p.user_id as user_id,
p.content
from users u
join posts p on u.id = p.user_id
我该怎么办? 我想要的不是sql查询,而是ruby语言的代码。感谢。
答案 0 :(得分:1)
您应该使用Dataset#select
来设置选择的列:
User.from{users.as(:u)}.join(Sequel[:posts].as(:p), user_id: :id).
select{[u[:id].as(:u_id), u[:name], u[:address],
p[:id].as(:p_id), p[:user_id].as(:user_id), p[:content]]}