foreach row insert foreach

时间:2014-10-06 13:40:34

标签: php mysql insert

我希望在我结束疯狂之前,有人可以帮助我。

我有3张桌子:

Table A
SELECT
companypk,
companyname,
logo,
msscope
FROM global_companies

表B

SELECT docpk, 
templatename, 
variation, 
doctype, 
modifydate, 
attachment, 
`scope`
FROM templates_documents 

表C

SELECT documentpk, 
companyfk, 
docref, 
doctitle, 
doctype, 
docowner, 
revision, 
issuedate, 
reasonforchange, 
status, 
attachment
FROM documents_doucments

没有一个表是相关的。然而,我想要实现的是当我在表A上添加一个新客户端时,我的代码查找它们在表A中具有的范围,然后将其与表B匹配,然后将相关文档插入到表C中。这是我的代码:

//Add Template Documentation
$sql = "SELECT doctype, templatename FROM templates_documents WHERE scope = '".$values["msscope"]."'";
$rs = CustomQuery($sql); 
$results = $rs;
while ($row = $results->fetch_assoc())
{
   "INSERT INTO documents_doucments (companyfk, doctype, doctitle) values('".$values["companypk"]."',$row[doctype], $row[templatename])";
}  

我知道查询部分正常工作,因为我已经尝试回显结果并且显示了正确的列但是它没有在表C中插入任何内容。到目前为止,我已经尝试过更改为foreach。我也是从client_after_add.php页面这样做的,这就是为什么companypk是一个会话字段,并与我的其他例子一起工作。

欢迎任何想法。

2 个答案:

答案 0 :(得分:1)

首先,您似乎没有将Insert语句发送到数据库中。仅仅在循环中编写一个字符串对数据库没有任何作用。

其次,您正在使用PHP来执行应在数据库中执行的功能。您可以在单个语句中执行SELECT和INSERT,如:

INSERT INTO documents_doucments (companyfk, doctype, doctitle) SELECT '".$values["companypk"]."', doctype, templatename FROM templates_documents WHERE scope = '".$values["msscope"]."'

答案 1 :(得分:0)

有效的代码是。

//Add Template Documentation
$sql = "SELECT doctype, templatename FROM templates_documents WHERE scope = '".$values["msscope"]."'";
$rs = CustomQuery($sql); 
$results = $rs;
while ($row = $results->fetch_assoc())
{
$sql2 = "INSERT INTO documents_doucments (companyfk, doctype, doctitle) values('".$values["companypk"]."','$row[doctype]','$row[templatename]')";CustomQuery($sql2);
}