将主键插入另一个包含2个单独插入的表中

时间:2013-06-14 17:06:12

标签: php sql sql-server

我的代码可能非常草率,这可能就是我不能让它工作的原因。 (注意:我正在使用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'的字段中插入第二个查询。

2 个答案:

答案 0 :(得分:0)

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

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

SELECT SCOPE_IDENTITY()

答案 1 :(得分: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
";