《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的使用实例详解所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)