2

我想仅根据数据库中的一些数据从数据库中转储一些数据。假设我有一个客户表和一个订单表。订单有一个外键给客户。订单由许多订单行(自己的表)构建而成,而这些订单行又具有项目(自己的表)。每个都通过 FK 链接。

为了从这个数据库中提取测试数据,我想以我可以处理的方式获取数据,比如 5 个订单。数据应该包含在我的应用程序中使用这些订单所需的一切(例如客户、商品、订单行)。而且我只想根据我想要的订单指定一些条件。

如果它确实重要,环境是:

  • JBoss 上的 JavaEE5
  • 休眠
  • 甲骨文 11g

我不反对使用任何可以让我以简单方式获取这些数据的语言或工具。

更新:我发现以下问题处理类似问题。

4

1 回答 1

1

这是个好问题。

Oracle 在 12c 中发布了一个测试管理包,我认为它可以解决这个问题 - 我没有深入了解它,但它可能也与 11g 兼容。Informatica 也有类似的产品。

如果您不想使用昂贵的解决方案,您可以使用 COPY 命令。COPYsqlplus命令的原理与旧的exp/类似,imp但它允许您使用查询导出。

1.导出查找表。

2.导出带有过滤器的主(事实)表。

copy from=user/pass@prod to user/pass@test create big_fact using select * from big_Fact where update_date > '01/01/2013'

3.通过join到基表复制相关表

copy from=user/pass@prod to user/pass@test create related_table1 using select related_table1.* from related_table1 join big_fact on (join_condition) where big_fact.update_date > '01/01/2013'

等等 ...

这不是一个健壮的解决方案,它与具有很少核心表和简单约束的模式兼容。

于 2013-07-04T20:09:49.613 回答