首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >设置关系Grocery CRUD

设置关系Grocery CRUD
EN

Stack Overflow用户
提问于 2011-12-03 23:06:24
回答 1查看 4.6K关注 0票数 0

我有两张桌子

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Users Table => id , username
OrdersTable => order_id,user_id, qty,total

我需要把这两张桌子连接起来。

id和user_id。

我怎么能用杂货渣做这件事。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-12-04 07:59:18

如果您使用OrdersTable作为您的主表,则可以使用关系()使用1:1关系。如果您正在查看订单,并希望查看/设置订单属于哪个用户,则会出现这种情况。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$crud->set_table('OrdersTable');
$crud->set_relation('id','UsersTable','username');

这将允许您为特定的订单选择哪个用户。

但是,想必一个用户可能有很多订单--一个1:n关系。如果UsersTable是您的主表,即您正在查看CRUD中的user并希望查看所有相关的订单,则会出现这种情况。

此方法需要中间表(与之链接两个现有表),以及对现有表结构的轻微更改。您需要删除user_id中的OrdersTable。为了进行名为UserOrdersTable的参数,中间表将需要以下列。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
user_id INT
order_id INT
priority INT

然后可以使用n()方法添加关系。

然后,您可以在查看set_relation_n_n()时反转OrdersTable调用,这样您就可以看到哪个用户下了订单。

总之,使用1:nset_relation_n_n()关系将允许您查看用户的订单,以及订单的用户。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8373873

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文