我希望在我发疯之前有人能帮我解决这个问题。
我有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中插入任何内容。到目前为止,我已经尝试更改while to foreach。我也是在client_after_add.php页面上这样做的,这就是为什么companypk是一个会话字段,并且可以与我的其他示例一起使用。
任何想法都是受欢迎的。
发布于 2014-10-06 21:52:05
首先,您似乎没有将Insert语句发送到数据库中。仅仅在循环中写一个字符串对数据库没有任何影响。
其次,您正在使用PHP执行应该在数据库中执行的功能。您可以在单个语句中执行SELECT和INSERT操作,如下所示:
INSERT INTO documents_doucments (companyfk, doctype, doctitle) SELECT '".$values["companypk"]."', doctype, templatename FROM templates_documents WHERE scope = '".$values["msscope"]."'发布于 2014-10-07 00:20:54
有效的代码是。
//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);
} https://stackoverflow.com/questions/26217521
复制相似问题