表连接SQL / PHP(CRUD)

时间:2012-05-08 17:13:34

标签: php mysql crud table-relationships

我有两张这样的表:

[tblFacilityHrs] id uid title description
[tblFacilityHrsDateTimes] id owner_uid startEventDate endEventDate startTime endTime days recurrence finalDate

他们通过UID处于一对多的关系中: enter image description here

enter image description here

我想加入表格,以便我只从tblFacilityHrsDateTimes获取ID值(这样当我编辑表格时,第一个表格tblFacilityHrs由UID编辑,tblFacilityHrsDateTimes由ID编辑)。

如何加入表格以便以这种方式进行编辑?

这样的事情:

<?php 
include('../config.php'); 
if (isset($_GET['uid']) ) { 
$uid = (int) $_GET['uid'];
$id = (int) $_GET['id'];  
if (isset($_POST['submitted'])) { 
foreach($_POST AS $key => $value) { $_POST[$key] = mysql_real_escape_string($value); } 

//Query for tblFacilityHrs
$sql = "`title` =  '{$_POST['title']}' ,  `description` =  '{$_POST['description']}'   WHERE `uid` = '$uid' "; 
mysql_query($sql) or die(mysql_error()); 

//Query for tblFacilityHrsDateTimes
$sql2 = "`startEventDate` =  '{$_POST['startEventDate']}' ,  `endEventDate` =  '{$_POST['endEventDate']}' ,  `startTime` =  '{$_POST['startTime']}',  `endTime` =  '{$_POST['endTime']}' ,  `days` =  '{$_POST['days']}' ,  `recurrence` =  '{$_POST['recurrence']} ,  `finalDate` =  '{$_POST['finalDate']}' WHERE `id` = '$id' "; 
mysql_query($sql2) or die(mysql_error()); 

echo (mysql_affected_rows()) ? "Edited row.<br />" : "Nothing changed. <br />"; 
echo "<a href='list.php'>Back</a>"; 
} 
$row = mysql_fetch_array (mysql_query("SELECT * FROM `tblFacilityHrs` WHERE `uid` = '$uid'"));
$row2 = mysql_fetch_array(mysql_query("SELECT * FROM `tblFacilityHrsDateTimes` WHERE `id` = '$id'"));
?>

在我的脑海中,我想像这样加入的表格(但它不起作用):

$result = mysql_query("SELECT uid, title, description FROM tblFacilityHrs LEFT JOIN tblFacilityHrsDateTimes ON tblFacilityHrs.uid = tblFacilityHrsDateTimes.owner_uid ORDER BY tblFacilityHrs.description") or trigger_error(mysql_error());

1 个答案:

答案 0 :(得分:2)

升级到答案

您需要从tblFacilityHrsDateTimes中选择结果集中的列:

SELECT      uid, title, description, tblFacilityHrsDateTimes.*
FROM        tblFacilityHrs
  LEFT JOIN tblFacilityHrsDateTimes
         ON tblFacilityHrs.uid = tblFacilityHrsDateTimes.owner_uid
ORDER BY    tblFacilityHrs.description