确定。这是我想要完成的。 我将更改保存到表单textarea,以便可以查看对该textarea所做的所有更改。就像一串评论。我把数据放到了两个表中。我需要帮助将其恢复原状。
我有两个表“worklog”和“worklognotes”中的数据。
worklog是来自具有textarea的表单的一系列工作订单,称为$ spec
worklognotes是对textarea $ spec
所做更改的运行列表在工作日志中,我将工作日志中的id保存为worklog_id,以便进行更改,数据将与正确的工作单匹配。
我可以很好地显示工作日志中的信息。但我根本看不到工作日志中的信息。我的目标是显示工作日志中的数据并在工作日志中显示记录WHERE worklognotes.worklog_id = worklog.id
我希望这是有道理的。像这样写出来有帮助。
这是我正在使用的查询语句。谢谢你的帮助。
$connection=mysql_connect ("localhost", "foo", "bar") or die ("I cannot connect to the database.");
$db=mysql_select_db ("database", $connection) or die (mysql_error());
$query = "SELECT * FROM worklog WHERE id=$id LIMIT 0,1";
$sql_result = mysql_query($query, $connection) or die (mysql_error());
$connection2=mysql_connect ("localhost", "foo", "bar") or die ("I cannot connect to the database.");
$db=mysql_select_db ("database", $connection2) or die (mysql_error());
$query2 = "SELECT * FROM worklognotes,worklog WHERE worklognotes.worklog_id=worklog.id ORDER BY worklog_id DESC";
$sql_result2 = mysql_query($query2, $connection2) or die (mysql_error());
- 续 - 09-13-10
这里是修改后的查询
$connection = mysql_connect ("localhost", "adsites_seth", "callie") or die ("I cannot connect to the database.");
$db = mysql_select_db ("adsites_cerebra", $connection) or die (mysql_error());
$query = "SELECT * FROM worklog ";
$query .= "LEFT JOIN worklognotes ON worklog_id = worklognotes.worklog_id ";
$query .= "WHERE worklog.id=worklognotes.worklog_id ORDER BY worklognotes.worklog_id ASC";
$sql_result = mysql_query($query, $connection) or die (mysql_error());
我在worklognotes表中有四个条目,所有四个条目都显示在一个页面上。 我只需要属于我正在查看的工作日志的一个条目,如果没有条目。什么都不显示。
答案 0 :(得分:3)
据我所知(如果我错了,请纠正我),你在工作日志和工作长度之间存在“一对多”的关系。
如果确实如此,那么您需要一个查询,它将为您提供由worklog.id“加入”的行。
未经测试,以下示例应该是有用的:
<?php
$connection = mysql_connect ("localhost", "foo", "bar") or die ("I cannot connect to the database.");
$db = mysql_select_db ("database", $connection) or die (mysql_error());
$query = "SELECT * FROM worklog ";
$query .= "LEFT JOIN worklognotes ON worklog.id = worklognotes.worklog_id ";
$query .= "WHERE worklog.id=$id ORDER BY worklognotes.worklog_id ASC";
$sql_result = mysql_query($query, $connection) or die (mysql_error());
?>
这可以给出类似的东西:
SELECT * FROM worklog LEFT JOIN worklognotes ON worklog.id = worklognotes.worklog_id
WHERE worklog.id=1 ORDER BY worklognotes.worknotes_id ASC;
+-------------+----------------+----------------------------------------+
| id | worknotes_id | log |
+-------------+----------------+----------------------------------------+
| 1 | 1 | Houses atre grate |
| 1 | 2 | Houses are grate |
| 1 | 3 | Houses are great |
| 2 | 4 | Shop5 are smelly |
| 2 | 5 | Shops are smelly |
| 2 | 6 | Shopes aren't smelly |
+-------------+---------------------------------------------------------+
获取给定worklog.id的所有工作日志:
SELECT * FROM worklog LEFT JOIN worklognotes ON worklog.id = worklognotes.worklog_id
WHERE worklog.id=1 AND worklog.id = 1 ORDER BY worklognotes.worknotes_id ASC;
+-------------+----------------+----------------------------------------+
| id | worknotes_id | log |
+-------------+----------------+----------------------------------------+
| 1 | 1 | Houses atre grate |
| 1 | 2 | Houses are grate |
| 1 | 3 | Houses are great |
+-------------+---------------------------------------------------------+