将数据导入一个新的 table,其中有一个嵌套的 table

Import Data to a new table that has a nested table in it

INSERT INTO OrderNew (
SalesOrderID,
OrderDate,
DueDate,
ShipDate,
OnlineOrderFlag,
CustomerID,
CreditCardID,
SubTotal,
TaxAmt,
Freight,
TotalDue,
OrderInfo.salesorderdetail,
OrderInfo.orderqty ,
OrderInfo.productid, 
OrderInfo.unitprice,
OrderInfo.unitpricediscount,
OrderInfo.linetotal
)
SELECT h."SalesOrderID" , h."OrderDate", h."DueDate", h."ShipDate", h."OnlineOrderFlag", h."CustomerID", h."CreditCardID", h."SubTotal", h."TaxAmt", h."Freight", h."TotalDue", d."SalesOrderDetailID", d."OrderQty", d."ProductID", d."UnitPrice", d."UnitPriceDiscount", d."LineTotal"
FROM "SalesOrderHeader" h
INNER JOIN "SalesOrderDetail" d ON  d."SalesOrderID" = h."SalesOrderID"
WHERE d."SalesOrderID" = h."SalesOrderID" ;

这是我用来从其他 table 导入数据的代码。 但是,我希望最后一列像嵌套的 table。 这些是我想成为的 table。因此,对于来自 table "SalesOrderHeader" 的一个销售订单 ID,在 table "SalesOrderDetail" 上有一对或更多条具有相同销售订单 ID 的记录。那么,我该怎么做呢?使用功能?

不知道我是不是一个可以理解的人。但我可以提供更多信息。

您创建了两种类型,以便稍微缩小新的 table,这将是 SalesOrderHeader 和 SalesOrderDetail 的组合。

CREATE TYPE Shipping AS(OrderDate Date,DueDate Date,ShipDate Date);

CREATE TYPE ordersdetails AS (details text);

然后你创建 table.

CREATE TABLE ordernew ( salesorderid serial NOT NULL, shippinginfo shipping, onlineorderflag integer, customerid serial NOT NULL, creditcardid integer, subtotal real, taxamt real, freight real, totaldue real, orderinfo ordersdetails[]);

至于数据,您只需复制其他两个 table 的数据,但要编写正确的查询以避免创建重复记录。所以,代码如下。

INSERT INTO OrderNew (
SalesOrderID,
OrderDate,
DueDate,
ShipDate,
OnlineOrderFlag,
CustomerID,CreditCardID,
SubTotal,
TaxAmt,
Freight,
TotalDue,
OrderInfo.salesorderdetail,
OrderInfo.orderqty ,
OrderInfo.productid,
OrderInfo.unitprice,
OrderInfo.unitpricediscount,
OrderInfo.linetotal
)
SELECT h."SalesOrderID" , h."OrderDate", h."DueDate", h."ShipDate", h."OnlineOrderFlag",
h."CustomerID", h."CreditCardID", h."SubTotal", h."TaxAmt", h."Freight", h."TotalDue",
d."SalesOrderDetailID", d."OrderQty", d."ProductID", d."UnitPrice", d."UnitPriceDiscount", d."LineTotal"
FROM "SalesOrderHeader" h
INNER JOIN "SalesOrderDetail" d ON d."SalesOrderID" = h."SalesOrderID"
WHERE d."SalesOrderID" = h."SalesOrderID" ;

要简单地查看您最近插入的数据 运行 以下查询:

SELECT orderinfo FROM ordernew;