[英]How to select record from two different tables
我有两个桌子
+----------------------------+
| task |
+----------------------------+
| id | t_title | t_assign_to |
+----------------------------+
+-----------------------------+
| task_employee |
+-----------------------------+
| id | emp_name | emp_underon |
+-----------------------------+
我的问题是我想从具有外键(t_assign_to)的task_employee表中的emp_underon ='2'的任务表中获取t_assign_to
<?php
$sql = mysql_query("SELECT * FROM task");/// i got all value from here
$sql=mysql_query("SELECT * FROM task_employee WHERE emp_underon ='2'");// i got all value from here
//$sql=mysql_query("SELECT * FROM task UNION SELECT * FROM task_employee WHERE emp_underon='2'");
$count = mysql_num_rows($sql);
while($row=mysql_fetch_assoc($sql))
{
echo $row['t_assign_to'];
}
?>
我认为t_assign_to是task_employee的外键,所以我将它们加入
模式1
$sql = "SELECT * FROM task t INNER JOIN task_employee te ON t.t_assign_to = te.id";
模式2
$sql = "SELECT * FROM task t,task_employee te WHERE t.t_assign_to = te.id";
如果表中的字段名称与其他表中的其他字段相同,则只需更改字段名称,例如:
$sql = "SELECT table.field as new_field_name FROM task t,task_employee te WHERE t.t_assign_to = te.id";
为了方便您
$sql = "SELECT * FROM task t INNER JOIN task_employee te ON t.t_assign_to = te.id WHERE te.emp_underon = '2' "
$q = mysql_query($sql);
$c = mysql_num_rows($q);
if($c > 0)
{
while($r = mysql_fetch_assoc($q))
{
echo $r['t_assign_to'];
}
}
我希望您可以通过此查询获得答案,尽管我没有测试此SQL。
select task.t_title, task.t_assign_to, task_employee.id as emp_id, task_employee.emp_name from task inner join task_employee on task.t_assign_to = task_employee.emp_underon where task_employee.emp_underon = 2
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.