我希望在我结束疯狂之前,有人可以帮助我。
我有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是一个会话字段,并与我的其他例子一起工作。
欢迎任何想法。
答案 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);
}