MySQL中,关联查询的3种写法…

看看下面三个关联查询的 SQL 语句有何区别?

[sql]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. SELECT FROM score, student WHERE score.id student.id ...  
  2. SELECT FROM score JOIN student ON (score.id student.id) WHERE ...  
  3. SELECT FROM score JOIN student USING (id) WHERE ...  
前两种写法,只是写法不同而已,其功能完全相同;最后一种,会将同名的列,合并起来。
第一种,是传统写法,SQL89标准里,就是这种;后面两种,是在SQL92标准才有的!
[sql]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. mysql> select from score;  
  2. +----+-------+  
  3. id score  
  4. +----+-------+  
  5.     60  
  6.     75  
  7.     90  
  8. +----+-------+  
  9. rows in set (0.00 sec)  
  10.   
  11. mysql> select from student;  
  12. +----+--------+  
  13. id name    
  14. +----+--------+  
  15.  张三    
  16.  李四    
  17.  王五    
  18. +----+--------+  
  19. rows in set (0.00 sec)  
  20.   
  21. mysql> select from score, student where score.id=student.id;  
  22. +----+-------+----+--------+  
  23. id score id name    
  24. +----+-------+----+--------+  
  25.     60  张三    
  26.     75  李四    
  27. +----+-------+----+--------+  
  28. rows in set (0.09 sec)  
  29.   
  30. mysql> select from score join student on score.id=student.id;  
  31. +----+-------+----+--------+  
  32. id score id name    
  33. +----+-------+----+--------+  
  34.     60  张三    
  35.     75  李四    
  36. +----+-------+----+--------+  
  37. rows in set (0.00 sec)  
  38.   
  39. mysql> select from score join student using(id);  
  40. +----+-------+--------+  
  41. id score name    
  42. +----+-------+--------+  
  43.     60 张三    
  44.     75 李四    
  45. +----+-------+--------+  
  46. rows in set (0.00 sec)  

附,下面是SQL发展的简要历史:
1986年,ANSI X3.135-1986,ISO/IEC 9075:1986,SQL-86 
1989年,ANSI X3.135-1989,ISO/IEC 9075:1989,SQL-89 
1992年,ANSI X3.135-1992, ISO/IEC 9075:1992,SQL-92(SQL2) 
1999年,ISO/IEC 9075:1999, SQL:1999(SQL3) 
2003年,ISO/IEC 9075:2003, SQL:2003(SQL4) 
200N年,ISO/IEC 9075:200N, SQL:200N(SQLN) 
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值