- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我开始学习cakephp 3,这将是我的学习项目。应用的思想是每个用户可以拥有很多产品,用户之间可以进行产品交易。工作流程:
到目前为止,这是我的数据库设计,但我认为这不是最好的解决方案,所以我希望你们能给我建议更好的解决方案(如果你们有的话)
如果我总结一切。当交易发生时,我需要知道谁在与谁交易什么(多种产品)以及接受、拒绝或重新选择交易产品。我也在寻找我的专栏的更有意义的名称。由于在某些时候用户的角色发生了变化,请求产品的人现在处于待定状态,反之亦然。
如果您需要任何其他信息,请告诉我,我会提供。提前谢谢你
最佳答案
我想您还有 products
表,其中包含 Id
、user_id
等列。
根据最后的评论,您当前的架构似乎不支持将 1 种产品交易到 10 种产品。为了支持这一点,我建议将表 products_users_trades
替换为 products_trades
包含列:Id
、product_id
、trade_id
、created_date
。
因此,让我们考虑在您的工作流中添加一些我认为可能需要的步骤以及您的架构将如何使用:
1.对于用户展示其产品的交易:
select t.id, p.name, t.user_id, t.user_id1 from trades as t
inner join product_trades as pt
on t.user_id = pt.trade_id or t.user_id1 = pt.trade_id
inner join products as p on p.id = pt.product_id
where t.user_id = 1 or t.user_id1 = 1
在这里,您可以使用 t.user_id
、t.user_id1
列来确定哪些产品是您的,哪些不是您的,哪些是您提供的或为您提供的。
2.显示哪些产品可以交易:
select * from products as p
where p.user_id = 1 and p.id not in
(select pt.product_id from trades as t
inner join product_trades as pt on t.id = pt.trade_id
where t.status_id = 1 and (t.user_id = 1 or t.user_id1 = 1))
此处 status_id = 1 表示新的锁定交易。要释放锁定,您需要将状态更改为接受或拒绝。
3.创建交易:
-- create a trade
insert into trades (status_id, user_id, user_id1) values (1, 1, 2);
-- insert all products in trade
insert into product_trades (product_id, trade_id) values (1, 1);
insert into product_trades (product_id, trade_id) values (1, 2);
4.检查用户是否可以接受或拒绝交易——检查此交易是否有 user_id1 = 他的用户 ID
5.接受或拒绝交易——改变交易状态。
6.要修改贸易 - 更改贸易修改数据并删除所有 product_trades
并创建新的。如果您需要在交易中显示更改的产品,那么您只需删除更改的产品,created_date
列将作为新产品的标识符。
关于mysql - 数据库模型所需的建议 - 附有部分 EER,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41857583/
我正在尝试创建一个 MySQL 将数据从 csv 加载到表中。 load data infile 'C:/ProgramData/MySQL/MySQL Server 8.0/Uploads/data
我有一个无法修复的小错误。这是笨蛋-> http://plnkr.co/edit/D3EjXKf48Sq2vuc5MHNx?p=preview 当用户打开模式并进行选择时,他选择按“确定”关闭模式 此
http://plnkr.co/edit/a5RpkuWJFMfnOgoKr7pm?p=preview 请引用插件链接。按照这个,我希望我的复选框位于最左侧,并且值“数据:”始终位于最右侧。我的意思是
我有一个脚本,在其中使用复选框和 javascript 在选中复选框时显示其他项目。这似乎在大多数时候都工作得很好。然而,有一个复选框会带来问题。我认为是因为与它相关的 javascript 魔法。当
Plunker-http://plnkr.co/edit/RVKzD9kXNNxinShK7nLU?p=preview 我有一个plunker,它显示日期和一个小图标,我们可以在其中选择我们想要的任何
我附上了以下插件 http://plnkr.co/edit/3H2q4eVJW5h0K3EdJIBe?p=preview 根据 plunker 的说法,我有 3 个无法解决的问题。 1) 当用户点
看了很多类似的问题后,我仍然不明白为什么我不能显示 jquery UI slider 。下面是我的代码。 正在加载js文件,css文件在同一位置。 (与html文件在同一个文件夹中) 我知道 jque
为什么这段代码不能访问'borderWidth'(附iphone代码) 这是基于一个简单的测试项目,但我确实添加了 QuartzCore 框架,但这没有帮助。仍然抛出错误,请参见下面的代码。我执行此操
我在 AppStore 中的应用程序中不断发生这些崩溃。 CrashReport 总是看起来像这样: Incident Identifier: 986486D7-F013-4102-B9E3-84F9
嘿UX设计师在这里学习代码,请原谅我的无知和蹩脚的代码。 我有一个 CSS 动画类型覆盖了一个 Hero Image,它也应用了 JS 效果。 最初我无法同时渲染这两个图像。该类型会呈现,但您看不到其
这是plunker代码。 http://plnkr.co/edit/C1khFJqTUutDaK9ad7ud?p=preview 我需要更改工具提示箭头。示例中工具提示的位置是顶部、底部和左侧。 谁能
我在底部提供了设计。 我希望在选项卡布局上方发生的事情: 我想要一个 AppBarLayout,它会在用户在其中一个选项卡中的 RecyclerView 上向下滚动时隐藏。 我希望用户图像附加到其背后
我正在尝试设置我的第二列“导师姓名”的样式,因为我使用了 css,它为整个网格提供了样式我还尝试了“control styl css class = (some other css file)”和“i
我是一名优秀的程序员,十分优秀!