Il database MySQL interno si unisce all'utilizzo di più tabelle? sinistra sinistra join efficienza di utilizzo

Database MySQLinner join utilizzo multi-tabella? sinistra sinistra join efficienza di utilizzo

mysql uso della connessione

Nei capitoli precedenti abbiamo imparato a leggere i dati da una tabella, il che è relativamente semplice, ma nelle applicazioni reali è spesso necessario leggere i dati da più tabelle di dati.

In questo capitolo ti mostreremo come usare JOIN di MySQL per interrogare i dati in due o più tabelle.

È possibile utilizzare le istruzioni JOIN di Mysql nelle istruzioni SELECT, UPDATE e DELETE per unire le query multi-tabella.

JOIN è approssimativamente suddiviso nelle seguenti tre categorie in base alla sua funzione:

  • INNER JOIN (inner join o equijoin): Ottieni record con campi corrispondenti in due tabelle.
  • UNISCITI A SINISTRA (unirsi a sinistra):Ottieni tutti i record nella tabella di sinistra, anche se non ci sono record corrispondenti nella tabella di destra.
  • RIGHT JOIN (right join): Contrariamente a LEFT JOIN, viene utilizzato per ottenere tutti i record nella tabella di destra, anche se non ci sono record corrispondenti corrispondenti nella tabella di sinistra.

Utilizzo di INNER JOIN nel prompt dei comandi

Abbiamo due tabelle tcount_tbl e chenweiliang_tbl nel database chenweiliang.I dati delle due tabelle dati sono i seguenti:

Esempio

Prova i seguenti esempi:

dati dell'istanza di test

mysql> use chenweiliang;
Database changed
mysql> SELECT * FROM tcount_tbl;
+---------------+--------------+
| chenweiliang_author | chenweiliang_count |
+---------------+--------------+
| 陈沩亮博客 | 10 |
| chenweiliang.com | 20 |
| Google | 22 |
+---------------+--------------+
3 rows in set (0.01 sec)
 
mysql> SELECT * from chenweiliang_tbl;
+-----------+---------------+---------------+-----------------+
| chenweiliang_id | chenweiliang_title | chenweiliang_author | submission_date |
+-----------+---------------+---------------+-----------------+
| 1 | 学习 PHP | 陈沩亮博客 | 2017-04-12 |
| 2 | 学习 MySQL | 陈沩亮博客 | 2017-04-12 |
| 3 | 学习 Java | chenweiliang.com | 2015-05-01 |
| 4 | 学习 Python | chenweiliang.com | 2016-03-06 |
| 5 | 学习 C | FK | 2017-04-05 |
+-----------+---------------+---------------+-----------------+
5 rows in set (0.01 sec)

Successivamente useremo MySQLINNER JOIN (puoi anche omettere INNER e usare JOIN, l'effetto è lo stesso)Per collegare le due tabelle precedenti per leggere il valore del campo chenweiliang_count corrispondente a tutti i campi chenweiliang_author nella tabella chenweiliang_tbl nella tabella tcount_tbl:

INNER JOIN

mysql> SELECT a.chenweiliang_id, a.chenweiliang_author, b.chenweiliang_count FROM chenweiliang_tbl a INNER JOIN tcount_tbl b ON a.chenweiliang_author = b.chenweiliang_author;
+-------------+-----------------+----------------+
| a.chenweiliang_id | a.chenweiliang_author | b.chenweiliang_count |
+-------------+-----------------+----------------+
| 1 | 陈沩亮博客 | 10 |
| 2 | 陈沩亮博客 | 10 |
| 3 | chenweiliang.com | 20 |
| 4 | chenweiliang.com | 20 |
+-------------+-----------------+----------------+
4 rows in set (0.00 sec)

L'istruzione SQL sopra è equivalente a:

Dove la clausola

mysql> SELECT a.chenweiliang_id, a.chenweiliang_author, b.chenweiliang_count FROM chenweiliang_tbl a, tcount_tbl b WHERE a.chenweiliang_author = b.chenweiliang_author;
+-------------+-----------------+----------------+
| a.chenweiliang_id | a.chenweiliang_author | b.chenweiliang_count |
+-------------+-----------------+----------------+
| 1 | 陈沩亮博客 | 10 |
| 2 | 陈沩亮博客 | 10 |
| 3 | chenweiliang.com | 20 |
| 4 | chenweiliang.com | 20 |
+-------------+-----------------+----------------+
4 rows in set (0.01 sec)

MySQL ha lasciato il join

Il join sinistro di MySQL è diverso da join. MySQL LEFT JOIN leggerà tutti i dati nella tabella dei dati di sinistra, anche se la tabella di destra non ha dati corrispondenti.

Esempio

Prova i seguenti esempi per chenweiliang_tbl per il tavolo di sinistra,tcount_tbl Per la tabella giusta, capire l'applicazione di MySQL LEFT JOIN:

LEFT JOIN

mysql> SELECT a.chenweiliang_id, a.chenweiliang_author, b.chenweiliang_count FROM chenweiliang_tbl a LEFT JOIN tcount_tbl b ON a.chenweiliang_author = b.chenweiliang_author;
+-------------+-----------------+----------------+
| a.chenweiliang_id | a.chenweiliang_author | b.chenweiliang_count |
+-------------+-----------------+----------------+
| 1 | 陈沩亮博客 | 10 |
| 2 | 陈沩亮博客 | 10 |
| 3 | chenweiliang.com | 20 |
| 4 | chenweiliang.com | 20 |
| 5 | FK | NULL |
+-------------+-----------------+----------------+
5 rows in set (0.01 sec)

Nell'esempio precedente viene utilizzato LEFT JOIN e questa istruzione leggerà tutti i dati del campo selezionato della tabella di dati chenweiliang_tbl a sinistra, anche se non esiste un valore di campo corrispondente di chenweiliang_author nella tabella tcount_tbl a destra.


MySQL GIUSTO UNISCITI

MySQL RIGHT JOIN leggerà tutti i dati nella tabella dati a destra, anche se non ci sono dati corrispondenti nella tabella a sinistra.

Esempio

Prova i seguenti esempi per chenweiliang_tbl per il tavolo di sinistra,tcount_tbl Per la tabella giusta, capire l'applicazione di MySQL RIGHT JOIN:

GIUSTO UNISCITI

mysql> SELECT a.chenweiliang_id, a.chenweiliang_author, b.chenweiliang_count FROM chenweiliang_tbl a RIGHT JOIN tcount_tbl b ON a.chenweiliang_author = b.chenweiliang_author;
+-------------+-----------------+----------------+
| a.chenweiliang_id | a.chenweiliang_author | b.chenweiliang_count |
+-------------+-----------------+----------------+
| 1 | 陈沩亮博客 | 10 |
| 2 | 陈沩亮博客 | 10 |
| 3 | chenweiliang.com | 20 |
| 4 | chenweiliang.com | 20 |
| NULL | NULL | 22 |
+-------------+-----------------+----------------+
5 rows in set (0.01 sec)

RIGHT JOIN viene utilizzato nell'esempio precedente, questa istruzione leggerà tutti i dati del campo selezionato della tabella di dati di destra tcount_tbl, anche se non esiste un valore di campo chenweiliang_author corrispondente nella tabella di sinistra chenweiliang_tbl.


Utilizzo di JOIN nello script PHP

La funzione mysqli_query() viene utilizzata in PHP per eseguire istruzioni SQL, è possibile utilizzare la stessa istruzione SQL di cui sopra come parametro per la funzione mysqli_query().

Prova il seguente esempio:

MySQL ORDINE PER test:

<?
php
$dbhost = 'localhost:3306'; // mysql服务器主机地址
$dbuser = 'root'; // mysql用户名
$dbpass = '123456'; // mysql用户名密码
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
 die('连接失败: ' . mysqli_error($conn));
}
// 设置编码,防止中文乱码
mysqli_query($conn , "set names utf8");
 
$sql = 'SELECT a.chenweiliang_id, a.chenweiliang_author, b.chenweiliang_count FROM chenweiliang_tbl a INNER JOIN tcount_tbl b ON a.chenweiliang_author = b.chenweiliang_author';
 
mysqli_select_db( $conn, 'chenweiliang' );
$retval = mysqli_query( $conn, $sql );
if(! $retval )
{
 die('无法读取数据: ' . mysqli_error($conn));
}
echo '<h2>陈沩亮博客 MySQL JOIN 测试<h2>';
echo '<table border="1"><tr><td>教程 ID</td><td>作者</td><td>登陆次数</td></tr>';
while($row = mysqli_fetch_array($retval, MYSQL_ASSOC))
{
 echo "<tr><td> {$row['chenweiliang_id']}</td> ".
 "<td>{$row['chenweiliang_author']} </td> ".
 "<td>{$row['chenweiliang_count']} </td> ".
 "</tr>";
}
echo '</table>';
mysqli_close($conn);
?>

Speranza Chen Weiliang Blog ( https://www.chenweiliang.com/ ) condiviso "Utilizzo multi-tabella di inner join nel database MySQL? left Left Join Usage Efficiency", ti aiuterà.

Benvenuti a condividere il link di questo articolo:https://www.chenweiliang.com/cwl-488.html

Benvenuto nel canale Telegram del blog di Chen Weiliang per ricevere gli ultimi aggiornamenti!

🔔 Sii il primo a ricevere la preziosa "Guida all'utilizzo dello strumento AI di marketing dei contenuti ChatGPT" nella directory principale del canale! 🌟
📚 Questa guida contiene un valore enorme, 🌟Questa è un'opportunità rara, non perderla! ⏰⌛💨
Condividi e metti mi piace se ti va!
La tua condivisione e i tuoi like sono la nostra continua motivazione!

 

发表 评论

L'indirizzo email non verrà pubblicato. 必填 项 已 用 * 标注

滚动 到 顶部