0

我的代码可能非常草率,这可能就是我无法让它工作的原因。(注意:我使用的是 php。)我的页面上有 2 个插入,我需要从第一个插入复制主键并在我的第二个插入中使用它。CustBill_billing 的主键是'bill_ID'。有没有办法在查询后输出 CustBill_billing 的主键,以便我可以在第二次插入时使用它?

第一个插入:

    $sql="
INSERT INTO CustBill_billing (C_ID, bolNum, type, le, waybill_date, bill_type, bol_date, con_name, con_city, con_state, ship_name, ship_city, ship_state, contract_num, weight, weight_cd, weight_auth, edc, fsac, ind, stcc, rr_from, rr_to, paymentMeth, unlDcd) 
VALUES ('1', '$pbolNum', '2', 'L', '$today', 'L', '$pbol_date', '$pcon_name', '$pcon_city', '$pcon_state', '$pship_name', '$pship_city', '$pship_state', '$pcontract_num', '$pweight', '$pweight_cd', 'A', 'RR', '1', '$pind', '$pstcc', '$prr_from', '$prr_to', '$ppaymentMeth', '$punlDcd')
";

第二次插入:

foreach($_POST['car_init'] as $key => $car_init)
{
$sql1 = "INSERT INTO CustBill_cars (C_ID, car_init, car_num, bolNum) VALUES ('1', '".$car_init."', '".$car_num[$key]."', '$pbolNum')
";

我将它们分开的原因是因为自动生成的文本框,我必须循环第二个插入;它检查数组中有多少个,然后将每个新记录插入到 CustBill_cars 表中。每次插入时,我都需要从第一次插入创建的主键插入到名为“carbill_ID”的字段中的第二个查询中。

4

2 回答 2

0

我想通了,我让它比需要的复杂得多。

$sql1 = "INSERT INTO CustBill_cars (C_ID, car_init, car_num, bolNum, bill_ID)
SELECT 1, '".$car_init."', '".$car_num[$key]."', $pbolNum, CustBill_billing.bill_ID
FROM CustBill_billing
";
于 2013-06-14T19:08:24.440 回答
0

在 SQL Server 中,如果您的 Id 字段是一个身份,那么您可以尝试 SCOPE_IDENTITY()。例如:

INSERT INTO dbo.MyTable(columns)
   VALUES(...)

SELECT SCOPE_IDENTITY()
于 2013-06-14T17:16:57.873 回答