关系数据库如何查询多表有联系数据? 一个数据库多对多关系表关联查询的问题

\u591a\u4e2a\u8868\u5173\u8054\u8868\u5982\u4f55\u67e5\u8be2\uff1f

\u5148\u8981\u628a\u6240\u6709\u7684\u8868\u90fd\u5173\u8054\u8d77\u6765\uff0c\u5728\u5199where\uff0con\u540e\u9762\u662f\u5173\u8054\u6761\u4ef6\uff0cwhere\u662f\u7b5b\u9009\u6761\u4ef6
select * from user
left join info on user.user_age = info.user_age
left join tyu on tyu.info_id=info.info_id --\u4ece\u7b2c\u4e00\u884c\u5230\u8fd9\u4e00\u884c\uff0c\u628a\u4e09\u4e2a\u8868\u5173\u8054\u8d77\u6765\u4e86\uff0c\u4f46\u53ef\u80fd\u4f1a\u6709\u91cd\u590d\u3002
where \u4f60\u9700\u8981\u7684\u7b5b\u9009\u6761\u4ef6\uff0c
\u8fd9\u91cc\u5199\u4f60\u9700\u8981\u7684\u7b5b\u9009\u6761\u4ef6\u3002
\u5173\u7cfb\u8868\uff1a
\u5173\u8054\u5173\u7cfb\u5fc5\u7136\u6709\u4e00\u4e2a\u53c2\u7167\u8868\uff0c\u4f8b\u5982\uff1a
\u6709\u4e00\u4e2a\u5458\u5de5\u6863\u6848\u7ba1\u7406\u7cfb\u7edf\u9879\u76ee\uff0c\u8fd9\u4e2a\u9879\u76ee\u8981\u5305\u62ec\u4e0b\u9762\u7684\u4e00\u4e9b\u6570\u636e\u8868\uff1a\u57fa\u672c\u4fe1\u606f\u8868\u3001\u5458\u5de5\u6863\u6848\u8868\u3001\u90e8\u95e8\u8868\u3001\u9879\u76ee\u7ec4\u8868\u3001\u94f6\u884c\u5361\u8868\uff08\u7528\u6765\u8bb0\u5f55\u5458\u5de5\u7684\u94f6\u884c\u5361\u8d44\u6599\uff09\u3002
\u8fd9\u4e9b\u6570\u636e\u8868\u4e4b\u95f4\u5b58\u5728\u4e00\u5b9a\u7684\u5173\u8054\u5173\u7cfb\uff0c\u6211\u4eec\u4ee5\u5458\u5de5\u57fa\u672c\u4fe1\u606f\u8868\u4e3a\u53c2\u7167\u6765\u5206\u6790\u548c\u5176\u4ed6\u8868\u4e4b\u95f4\u7684\u5173\u8054\uff1a
\u6bcf\u4e2a\u5458\u5de5\u5fc5\u7136\u6709\u5bf9\u5e94\u7684\u5458\u5de5\u6863\u6848\u8d44\u6599\uff0c\u6240\u4ee5\u5c5e\u4e8eHAS_ONE\u5173\u8054\uff1b
\u6bcf\u4e2a\u5458\u5de5\u5fc5\u987b\u5c5e\u4e8e\u67d0\u4e2a\u90e8\u95e8\uff0c\u6240\u4ee5\u5c5e\u4e8eBELONGS_TO\u5173\u8054\uff1b
\u6bcf\u4e2a\u5458\u5de5\u53ef\u4ee5\u6709\u591a\u4e2a\u94f6\u884c\u5361\uff0c\u4f46\u662f\u6bcf\u5f20\u94f6\u884c\u5361\u53ea\u53ef\u80fd\u5c5e\u4e8e\u4e00\u4e2a\u5458\u5de5\uff0c\u56e0\u6b64\u5c5e\u4e8eHAS_MANY\u5173\u8054\uff1b
\u6bcf\u4e2a\u5458\u5de5\u53ef\u4ee5\u540c\u65f6\u5728\u591a\u4e2a\u9879\u76ee\u7ec4\uff0c\u6bcf\u4e2a\u9879\u76ee\u7ec4\u540c\u65f6\u6709\u591a\u4e2a\u5458\u5de5\uff0c\u56e0\u6b64\u5c5e\u4e8eMANY_TO_MANY\u5173\u8054\uff1b
\u5206\u6790\u6e05\u695a\u6570\u636e\u8868\u4e4b\u524d\u7684\u5173\u8054\u5173\u7cfb\u540e\uff0c\u6211\u4eec\u624d\u53ef\u4ee5\u8fdb\u884c\u5173\u8054\u5b9a\u4e49\u548c\u5173\u8054\u64cd\u4f5c\u3002
\u6570\u636e\u5e93\uff1a
\u4e24\u4e2a\u6570\u636e\u5e93\u53ca\u5176\uff08\u6570\u636e\uff09\u8868\u4e4b\u95f4\u7684\u6570\u636e\u7684\u76f8\u4e92\u4f9d\u8d56\u548c\u5f71\u54cd\u5173\u7cfb\u3002
\u6bd4\u5982\u73b0\u6709\u67d0\u5b66\u6821\u4e09\u4e2a\u6570\u636e\u8868\uff1a\u5b66\u751f\uff08\u5b66\u53f7\uff0c\u59d3\u540d\uff09\uff0c\u8bfe\u7a0b\uff08\u8bfe\u7a0b\u540d\uff0c\u8bfe\u7a0b\u7f16\u53f7\uff09\uff0c\u9009\u8bfe\uff08\u5b66\u53f7\uff0c\u8bfe\u7a0b\u53f7\uff0c\u6210\u7ee9\uff09\u3002\u9009\u8bfe\u8868\u4e2d\u7684\u201c\u5b66\u53f7\u201d\uff0c\u201c\u8bfe\u7a0b\u53f7\u201d\u5fc5\u987b\u662f\u53e6\u5916\u4e24\u4e2a\u8868\u4e2d\u5b58\u5728\u7684\u6570\u636e\uff0c\u624d\u6709\u610f\u4e49\uff1b\u800c\u4e14\u4e00\u65e6\u53e6\u5916\u4e24\u8868\u4e2d\u7684\u67d0\u4e00\u5b66\u751f\u6216\u8bfe\u7a0b\u88ab\u5220\u9664\uff0c\u9009\u8bfe\u8868\u4e2d\u7684\u76f8\u5e94\u5b66\u53f7\u6216\u8bfe\u7a0b\u53f7\u5fc5\u987b\u81ea\u52a8\u5220\u9664\u3002\u8fd9\u5c31\u662f\u4e00\u79cd\u5173\u8054\u5173\u7cfb\u3002\u5b83\u5b9e\u9645\u4e0a\u662f\u4fdd\u8bc1\u6570\u636e\u5b8c\u6574\u6027\u7684\u4e00\u79cd\u505a\u6cd5\u3002

select p.c_p,pt.c_t from p left join pt on p.c_p=pt.c_p and pt.c_pt='X';


***\u8865\u5145\uff1a*******
\u4f60\u8bf4\u7684\u8fd9\u4e2a\u53ef\u4ee5\u529e\u5230\uff0c\u4f46\u662f\u6211\u770b\u4e0d\u51fa\u6709\u4ec0\u4e48\u610f\u4e49\u3002
\u65f6\u95f4\u5173\u7cfb\u6211\u53ea\u8bf4\u8bf4\u65b9\u6cd5\u4e86\uff0c\u671b\u89c1\u8c05\u3002
1\u3001\u5148\u5173\u8054t\u8868\u548cpt\u8868\uff08\u53ef\u4ee5\u5148\u5efa\u4e00\u4e2a\u4e34\u65f6\u89c6\u56fe\uff09
2\u3001\u518d\u5728\u5173\u8054\u7684\u57fa\u7840\u4e0a\u7528\u4e0a\u9762\u7684sql\uff0c\u53ea\u4e0d\u8fc7\u628apt\u8868\u6362\u62101\u4e2d\u5173\u8054\u7684\u7ed3\u679c\u3002
****************


--
\u4ee5\u4e0a\uff0c\u5e0c\u671b\u5bf9\u4f60\u6709\u6240\u5e2e\u52a9\u3002

关联查询是日常工作中常用的查询方式,关联查询sql编写的思路一般如下:1、先确定所连接的表,2、再确定所要查询的字段,3、确定连接条件以及连接方式(表连接分类: 内连接、外连接、交叉连接、自连接)
1、内连接:[inner] join on
分类:等值连接、非等值连接
(1)等值连接: 指使用等号"=“比较两个表的连接列的值,相当于两表执行笛卡尔后,取两表连结列值相等的记录(自然连接是一种特殊的等值连接)(2)非等值连接:指使用”>“或”<"比较两个表的连接列的值,相当于两表执行笛卡尔后,取一个表大于或小于另一个表的连结列值的记录
2、外连接
分类:左外连接、右外连接、全外连接
(1)左外连接:left outer join
连接效果:查询结果包含左、右两个表需要查询的全部行,左侧的表中的全部数据都会被显示出来,但是右侧表的数据,只有和左侧匹配上的数据才会被查询出来!否则显示为null(2)右外连接:right outer join
连接效果:查询结果包含左、右两个表需要查询的全部行,右侧的表中的全部数据都会被显示出来,但是左侧表的数据,只有和右侧匹配上的数据才会被查询出来!否则显示为null(3)全外连接:full/all outer join,查询结果包含左、右两个表需要查询的全部行,对应字段没有值显示null
3、交叉连接
左表中的每一行与右表中的所有行组合,也叫表与表之间做笛卡尔积查询
4、自连接
当前表与自身的连接查询,关键点在于虚拟化出一张表,即给自身的表定义一个别名

  • 鍏崇郴鏁版嵁搴撳浣曟煡璇㈠琛ㄦ湁鑱旂郴鏁版嵁?
    绛旓細鍏宠仈鏌ヨ鏄棩甯稿伐浣滀腑甯哥敤鐨勬煡璇㈡柟寮忥紝鍏宠仈鏌ヨsql缂栧啓鐨勬濊矾涓鑸涓嬶細1銆佸厛纭畾鎵杩炴帴鐨勮〃锛2銆佸啀纭畾鎵瑕佹煡璇㈢殑瀛楁锛3銆佺‘瀹氳繛鎺ユ潯浠朵互鍙婅繛鎺ユ柟寮锛堣〃杩炴帴鍒嗙被锛 鍐呰繛鎺ャ佸杩炴帴銆佷氦鍙夎繛鎺ャ佽嚜杩炴帴锛1銆佸唴杩炴帴锛歔inner] join on 鍒嗙被锛氱瓑鍊艰繛鎺ャ侀潪绛夊艰繛鎺 锛1锛夌瓑鍊艰繛鎺ワ細 鎸囦娇鐢ㄧ瓑鍙"=鈥滄瘮杈冧袱...
  • Mysql鍩虹绡(涓)涔澶氳〃鏌ヨ
    绛旓細2. 澶氳〃鏌ヨ涔嬫梾棣栧厛锛岀悊瑙e琛ㄦ煡璇㈢殑瑕侀锛屽寘鎷鏁版嵁鍑嗗鍜屾煡璇㈢瓥鐣ャ傛垜浠粠鍒犻櫎鏃ц〃寮濮嬶紝鍒涘缓鏂扮殑emp鍜宒ept琛紝骞跺~鍏呮祴璇曟暟鎹傛帴涓嬫潵锛屾垜浠皢浠庣畝鍗曠殑绗涘崱灏旂Н鏌ヨ鍒板鏉傜殑鍏宠仈鎿嶄綔锛屽鍐呰繛鎺ャ佸杩炴帴鍜岃嚜杩炴帴銆3. 鏌ヨ鑹烘湳锛氳繛鎺ヤ笌绛涢夊師鏉ワ紝鍗曡〃鏌ヨ鍙渶`SELECT * FROM emp`锛岃屽琛ㄦ煡璇紙濡...
  • 鎵撳紑浜嗕竴涓猘ccess鏁版嵁搴,閲岄潰寰堝琛,濡備綍鏌ョ湅瀹冧滑涔嬮棿鐨鑱旂郴?
    绛旓細鐐瑰嚮鑿滃崟涓婇潰鐨勨滃伐鍏封->鈥鍏崇郴鈥濓紝鎴栨槸鍦ㄦ病鏈夎〃鐨勭┖鐧藉鐐瑰彸閿紝鐒跺悗閫夋嫨鍏崇郴灏卞彲浠ユ墦寮鍏崇郴瑙嗗浘浜嗐
  • 鏁版嵁搴SQLyog涔澶氳〃鏌ヨ
    绛旓細涓瀵逛竴鍏崇郴锛屽user涓巙ser_text锛屾垜浠敤JOIN鎴朓NNER JOIN鏉ョ‘淇鏁版嵁鐨勭簿纭尮閰嶃傚浜庝竴瀵瑰鎴栧瀵澶氬叧绯锛屾瘮濡俿tudent涓巗core锛屾垜浠彲浠ヤ粠涓嶅悓瑙掑害鐪嬪緟锛屽鏌ヨ瀛︾敓鐨勬墍鏈夋垚缁╂垨璇剧▼锛岄氳繃JOIN鍜孫N璇彞杩炴帴琛ㄨ繘琛屾煡璇傚瀵瑰鍏崇郴锛屽teacher涓巗tu锛岄氬父閫氳繃涓棿琛╰ea stu鏉ョ淮鎶ゅ叧鑱斻侸OIN鎿嶄綔鍦ㄦ鍦烘櫙涓嬪挨涓...
  • 鏁版嵁搴閲屾湁寰堝琛,濡備綍鏌ョ湅琛ㄤ笌琛ㄤ箣闂寸殑鍏崇郴鍛?
    绛旓細鍦鏁版嵁搴撳叧绯鍥鹃噷鏂板缓涓涓暟鎹簱鍏崇郴鍥 鐐瑰嚮鏂板缓鍚庡湪鍑烘潵鐨勭晫闈㈢偣娣诲姞 鎶婃墍鏈夎〃閮藉~杩涘幓 杞悗鐐瑰叧闂 鍏崇郴鍥惧氨鍑烘潵浜 闅忚蒋鐪嬭捣鏉ヨ繕鏈夌偣涔 浣嗘槸閭d簺琛ㄤ箣闂存湁鍏崇郴宸茬粡鑳界湅鍑烘潵浜 濡傚鍌茶鏄庣‘鐐 閭d箞浣犲氨鑷繁鎷 閭d簺绾挎槸鍙互鎷栫殑 閽ュ寵浠h〃琚閿紩鐢ㄧ殑閿 ...
  • sql璇彞澶氳〃鍏宠仈鎬庝箞鏌ヨ?
    绛旓細鐢⊿ELECT瀵澶氳〃鍏宠仈杩涜鏌ヨ銆係QL鏄竴绉嶇壒娈婄洰鐨勭殑缂栫▼璇█锛屾槸涓绉嶆暟鎹簱鏌ヨ鍜岀▼搴忚璁¤瑷锛岀敤浜庡瓨鍙栨暟鎹互鍙婃煡璇佹洿鏂板拰绠$悊鍏崇郴鏁版嵁搴绯荤粺锛涘悓鏃朵篃鏄暟鎹簱鑴氭湰鏂囦欢鐨勬墿灞曞悕銆傜粨鏋勫寲鏌ヨ璇█鏄珮绾х殑闈炶繃绋嬪寲缂栫▼璇█锛屽厑璁哥敤鎴峰湪楂樺眰鏁版嵁缁撴瀯涓婂伐浣溿傚畠涓嶈姹傜敤鎴锋寚瀹氬鏁版嵁鐨勫瓨鏀炬柟娉曪紝涔熶笉闇瑕佺敤鎴蜂簡瑙...
  • 涓涓鏁版嵁搴撳瀵澶氬叧绯昏〃鍏宠仈鏌ヨ鐨勯棶棰
    绛旓細left join pt on p.c_p=pt.c_p and pt.c_pt='X';琛ュ厖锛氫綘璇寸殑杩欎釜鍙互鍔炲埌锛屼絾鏄垜鐪嬩笉鍑烘湁浠涔堟剰涔夈傛椂闂鍏崇郴鎴戝彧璇磋鏂规硶浜嗭紝鏈涜璋呫1銆佸厛鍏宠仈t琛ㄥ拰pt琛紙鍙互鍏堝缓涓涓复鏃惰鍥撅級2銆佸啀鍦ㄥ叧鑱旂殑鍩虹涓婄敤涓婇潰鐨剆ql锛屽彧涓嶈繃鎶妏t琛ㄦ崲鎴1涓叧鑱旂殑缁撴灉銆-- 浠ヤ笂锛屽笇鏈涘浣犳湁鎵甯姪銆
  • 鏁版嵁搴撳琛鍏宠仈闂
    绛旓細鏁版嵁搴撳琛鍏宠仈锛氬湪鍏崇郴鍨嬫暟鎹簱涓紝澶氳〃鍏宠仈鏂瑰紡鏄奖鍝嶆ц兘鏈澶х殑鎶鏈紝鎶妋ysql瀹氫箟涓轰腑灏忓瀷鏁版嵁搴撶殑涓昏鍘熷洜鏄痬ysql鏄笉鏀寔hash join鐨勶紝杩欏澶氫釜澶ц〃鍏宠仈鏌ヨ閫犳垚鎬ц兘鐨勭摱棰堬紝鍥犳锛屽湪澶ф暟鎹鍩燂紝姣旇緝灏戜娇鐢╩ysql浣滀负鍚庡彴鏁版嵁搴擄紝浣跨敤mysql锛岄渶瑕佹妸琛ㄨ璁′负瀹借〃锛岃繘琛屽弽鑼冨紡璁捐锛屽噺灏戝琛ㄥ叧鑱旓紝铏界劧鍗...
  • Oracle 10g濡備綍瀹炵幇楂樼骇鏌ヨ
    绛旓細1銆佸熀鏈繛鎺鏌ヨ 鍦ㄧ畝鍗曟煡璇腑鎴戜滑涓鑸彧浣跨敤浜唂rom瀛楀彞鐨勪竴涓〃锛岀劧鑰屽湪鍏崇郴鏁版嵁搴涓紝琛ㄤ笌琛ㄤ箣闂村線寰鏄瓨鍦ㄥ叧绯荤殑锛岃繖灏辨槸瑕佹眰浠庡涓〃涓绱㈡暟鎹紝浠ヨ緭鍑烘洿鏈夋剰涔夌殑缁撴灉銆傛渶绠鍗曠殑杩炴帴鏂瑰紡灏辨槸鍦╯elect璇彞涓紝閫氳繃from瀛愬彞浣跨敤澶氫釜琛紝骞剁敤閫楀彿灏嗕笉鍚岀殑鍩烘湰琛ㄩ殧寮銆備笅闈㈣鍙ュ皢鍟嗗搧淇℃伅琛ㄥ拰渚涘簲鍟嗕俊鎭...
  • 鏁版嵁搴涓寮犺〃鐨勬墍鏈夊瓧娈甸兘鐩稿悓,鎬庝箞鐢ㄤ竴鏉ql璇彞鏌ヨ杩欎簺鏁版嵁鐨勪釜鏁...
    绛旓細set @i=1 while @i<10 begin set @sql='select count(*) from table'+convert(varchar,@i)exec @sql end 浜屻佹妸琛ㄥ悕浠庣郴缁熻〃閲屽彇鍑猴紝鏉ョ粍鎴恠ql select ''select count(*) from '+name from sysobjects where xtype='u'鍐嶆妸sql鍙栧嚭鏉ユ墽琛屾棦鍙備笁銆佸鏋滀綘鏈夊叴瓒g爺绌讹紝杩樺彲浠ヤ娇鐢ㄥ井杞湭...
  • 扩展阅读:个人档案如何查询 ... 属于关系型数据库的是 ... 免费查询个人证件信息 ... vlookup if多条件查询 ... 姓名查询身份证号码 ... 数据库多条件查询 ... 大量数据一对多匹配 ... 如何查询数据库中的表 ... 个人档案查询网上查询系统官网 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网