Mysql入门Mysql中Join的使用实例详解

Mysql入门Mysql中Join的使用实例详解,第1张

概述介绍《Mysql入门Mysql中Join的使用实例详解》开发教程,希望对您有用。

《MysqL入门MysqL中Join的使用实例详解》要点:
本文介绍了MysqL入门MysqL中Join的使用实例详解,希望对您有用。如果有疑问,可以联系我们。

在前几章节中,我们已经学会了如果在一张表中读取数据,这是相对简单的,但是在真正的应用中经常需要从多个数据表中读取数据.
MysqL数据库

本章节我们将向大家介绍如何使用MysqL 的 JOIN 在两个或多个表中查询数据.MysqL数据库

你可以在SELECT,UPDATE 和 DELETE 语句中使用MysqL 的 join 来联合多表查询.MysqL数据库

以下我们将演示MysqL left JOIN 和 JOIN 的使用的不同之处.MysqL数据库

在命令提示符中使用JOINMysqL数据库

我们在RUNOOB数据库中有两张表 tcount_tbl 和 runoob_tbl.两张数据表数据如下:MysqL数据库

实例MysqL数据库

尝试以下实例:MysqL数据库

root@host# MysqL -u root -p password;Enter password:*******MysqL> use RUNOOB;Database changedMysqL> SELECT * FROM tcount_tbl;+-----------------+----------------+| runoob_author | runoob_count |+-----------------+----------------+| mahran   |    20 || mahnaz   |   NulL || Jen    |   NulL || Gill   |    20 || John Poul  |    1 || Sanjay   |    1 |+-----------------+----------------+6 rows in set (0.01 sec)MysqL> SELECT * from runoob_tbl;+-------------+----------------+-----------------+-----------------+| runoob_ID | runoob_Title | runoob_author | submission_date |+-------------+----------------+-----------------+-----------------+|   1 | Learn PHP  | John Poul  | 2007-05-24  ||   2 | Learn MysqL | Abdul S   | 2007-05-24  ||   3 | JAVA Tutorial | Sanjay   | 2007-05-06  |+-------------+----------------+-----------------+-----------------+3 rows in set (0.00 sec)MysqL>

接下来我们就使用MysqL的JOIN来连接以上两张表来读取runoob_tbl表中所有runoob_author字段在tcount_tbl表对应的runoob_count字段值:MysqL数据库

MysqL> SELECT a.runoob_ID,a.runoob_author,b.runoob_count -> FROM runoob_tbl a,tcount_tbl b -> WHERE a.runoob_author = b.runoob_author;+-------------+-----------------+----------------+| runoob_ID | runoob_author | runoob_count |+-------------+-----------------+----------------+|   1 | John Poul  |    1 ||   3 | Sanjay   |    1 |+-------------+-----------------+----------------+2 rows in set (0.01 sec)MysqL>

在PHP脚本中使用JOINMysqL数据库

PHP 中使用MysqL_query()函数来执行SQL语句,你可以使用以上的相同的SQL语句作为MysqL_query()函数的参数.MysqL数据库

尝试如下实例:MysqL数据库

<?PHP$dbhost = 'localhost:3036';$dbuser = 'root';$dbpass = 'rootpassword';$conn = MysqL_connect($dbhost,$dbuser,$dbpass);if(! $conn ){ dIE('Could not connect: ' . MysqL_error());}$sql = 'SELECT a.runoob_ID,b.runoob_count  FROM runoob_tbl a,tcount_tbl b  WHERE a.runoob_author = b.runoob_author';MysqL_select_db('RUNOOB');$retval = MysqL_query( $sql,$conn );if(! $retval ){ dIE('Could not get data: ' . MysqL_error());}while($row = MysqL_fetch_array($retval,MysqL_ASSOC)){ echo "Author:{$row['runoob_author']} <br> ".   "Count: {$row['runoob_count']} <br> ".   "Tutorial ID: {$row['runoob_ID']} <br> ".   "--------------------------------<br>";} echo "Fetched data successfully\n";MysqL_close($conn);?>

MysqL left JOINMysqL数据库

MysqL left join 与 join 有所不同. MysqL left JOIN 会读取左边数据表的全部数据,即便右边表无对应数据.MysqL数据库

实例MysqL数据库

尝试以下实例,理解MysqL left JOIN的应用:MysqL数据库

root@host# MysqL -u root -p password;Enter password:*******MysqL> use RUNOOB;Database changedMysqL> SELECT a.runoob_ID,b.runoob_count -> FROM runoob_tbl a left JOIN tcount_tbl b -> ON a.runoob_author = b.runoob_author;+-------------+-----------------+----------------+| runoob_ID | runoob_author | runoob_count |+-------------+-----------------+----------------+|   1 | John Poul  |    1 ||   2 | Abdul S   |   NulL ||   3 | Sanjay   |    1 |+-------------+-----------------+----------------+3 rows in set (0.02 sec)

以上实例中使用了left JOIN,该语句会读取左边的数据表runoob_tbl的所有选取的字段数据,即便在右侧表tcount_tbl中没有对应的runoob_author字段值.MysqL数据库

以上所述是小编给大家介绍的MysqL中Join的使用实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的.在此也非常感谢大家对内存溢出网站的支持!MysqL数据库

总结

以上是内存溢出为你收集整理的Mysql入门Mysql中Join的使用实例详解全部内容,希望文章能够帮你解决Mysql入门Mysql中Join的使用实例详解所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1164105.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存