0

我有一个表单 request_form.php,即管理请求项目的采购请求表单。

Purchase_Request_No:(自动 - 自动增量)
日期:
部门:
供应商:
Item_Request:
示例有 5 行:
1.
2.
3.
4.
5。

我想在购买请求有 1 个 Purchase_Request_No 时进行。
示例 :

Purchase_Request_No : 17
Date :25-Jul-2012
Dept :Production
供应商 :Microsoft
Item_Request :
1.Windows XP Professional
2.Keyboard
3.Mouse
4.LCD Monitor
5.Speaker

那么,我怎样才能使用 1 Purchase_Request_No 并且项目请求超过 1 个项目(在这种情况下我放置 5 个项目)?

任何人都可以帮助我吗?感谢提前。


大家好,现在又回来了,我已经在编写这个概念了。它已成功将数据保存到数据库中,但仍然在插入 5 个项目时,它会按每个 ID 提交每个项目的数据。示例:
第 1 项 - 计算机(第 1 次购买)
第 2 项 - 鼠标(第 2 次购买)
我想要的是:
第 1 项 - 计算机(第 1 次购买)
第 2 项 - 鼠标(第 1 次购买)

这是我的代码:我使用自动增量购买。

<?php
$conn = oci_connect("system", "dev01");
$n = $_POST['jum'];
for ($i=1; $i<=$n; $i++)
{
$dept=$_POST['dept'];
$date_request=$_POST['date_request'];
$supplier=$_POST['supplier'];   

$item=$_POST['item'.$i];    
$qty=$_POST['qty'.$i];  
$uprice=$_POST['uprice'.$i];    
$total=$_POST['total'.$i];  

$s = oci_parse($conn,
"insert into purchase_request(dept_id, supplier_id, date_request, item, qty, uprice, total_amount) values ('$dept', '$supplier', '$date_request', '$item'
, '$qty', '$uprice', '$total'
)");

$r = oci_execute($s);

oci_rollback($conn);

echo "Data was committed\n";
}
?>

任何的想法 ?

4

2 回答 2

2

有三张桌子。一个将包含以下产品:

id    Product
1     Windows XP Professional
2     Keyboard
3     Mouse
4     LCD Monitor
5     Speaker

另一个包含请求:

id    request_date    dept       supplier
1     25-Jul-2012     Production Microsoft

第三个将前两个映射在一起

id  request_id  item_id
1   1           1
2   1           2
3   1           3
4   1           4
5   1           5

(或者,您可以将产品的 id 设为素数并将items列存储为项目的倍数。您需要做的就是找到items列的素数,然后您就得到了项目列表!*)

*出于某种原因,工作中没有人认为这是一个好主意。

于 2012-07-27T03:20:40.277 回答
-1

最好的做法是创建两个表说

Purchase
Purchase_Id (Primary Key)
Supplier_Id: (foreign key referring Supplier table)
Purchase_date: datetime

Purchase_Items_Details
purchase_item_id (primary key)
purchase_id (foreign key to Purchase table)
item_id (foreign key to Products/Items table)
qty (Quantity)

Purchase表格中,您将仅输入基本购买详细信息,有关购买的详细信息将添加到Purchase_Items_Details

于 2012-07-27T03:21:23.867 回答