多對多關系sql
『壹』 sql怎麼構建多對多關系表
CREATE TABLE 教師
(教師工號 類型 PRIMARY KEY,
教師姓名 類型,
教師地址 類型,
教師電話 類型)
CREATE TABLE 課程信息
(課程編號 類型 PRIMARY KEY,
課程名稱 類型,
信息備注 類型)
CREATE TABLE 任課
(教師工號 類型 REFERENCES 教師(教師工號),
課程編號 類型 REFERENCES 課程信息(課程編號),
PRIMARY KEY(教師工號,課程編號))
『貳』 在SQL中怎麼創建一個多對多的表,分析實體,找出關系模式,並定義它們之間的關系
首先建立兩個表
分別對應兩個實體
然後建立第三張表作為中間表
將之前建好的兩個表的主鍵在中間表中做聯合主鍵
這樣就將兩張表的多對多關系聯系起來了
我舉個例子
一條微博可能屬於多個話題
一個話題中也包含多條微博
--------------
話題表------
create
table
topic
(
topicid
int
primary
key,
keyword
nvarchar2(50)
not
null,
topictype
nvarchar2(50)
not
null
check(topictype
in
('生活','情感','娛樂','電影','電視','體壇','財經','科技','文化','媒體沙龍')),
);
-----、微博表——————
create
table
weibo(
weiboid
int
primary
key,
userID
int
,
text
nvarchar2(140)not
null,
);
---------、話題微博表
create
table
topicWeibo
(
topicweiboid
int
primary
key,
weiboid
int
references
weibo(weiboid),
topicid
int
references
topic(topicid)
);
『叄』 sql 多對多查詢
select *
from
(select id,sum(money) as mm from a表 group by id) aaa,
(select id,sum(money) as nn from b表 group by id) bbb
where aaa.id=bbb.id and aaa.mm=bbb.nn;
-----------------------------
說明:
先用語句,得到aaa,bbb兩個臨時表,裡面是(ID,錢的求和);
然後疊加一個查詢,從表aaa,表bbb中,用條件,篩選出需要的記錄(ID相等,錢求和相等);mm,nn是我為了欄位查看方便,設置的兩個臨時欄位名。
-----------------------------
如果你是用workbench,語句正確執行要寫成一行。
『肆』 資料庫表與表之間多對多關系怎麼處理
拆分關系,增加一個表,使之符合範式。
『伍』 在SQL中要建立這樣一個表,可以實現多對多的關系
想建立多對多的關系只是通過兩張表是不行的,需要增加另外一張班級流程關系表來存儲這種關系,這樣才可以做到多對多的關系,同時也比較符合資料庫表的設計要求。
----------------------
補充回答:
就以你這個例子來說,建立一個班級流程表,其主要組成為:
流程編號
varchar(10),主鍵
班級名稱
varchar(10),主鍵
而且這兩個欄位分別也都是外鍵。
『陸』 sql多對多關系的兩表如何聯合查詢出所有的結果
1、語句如下:
Select project.*, [contract].* from project
Left join contract_project on project.projectId = contract_project.projectId
Left join [contract] on contract_project.contractId = [contract].contractId
註:contract在Sql server中是關鍵字,因此使用了中括弧。
2、使用Left join
Left join是以左表為準的。換句話說,左表(project)的記錄將會全部表示出來,而右表(contract_project)只會顯示符合搜索條件的記錄
(例子中為: project.projectId = contract_project.projectId)。對於contract表來說,contract_project表是它的左表。
此例以兩個left join 將三個表按條件聯接在一起。
(6)多對多關系sql擴展閱讀
連接通常可以在select語句的from子句或where子句中建立,其語法格式為:
selectcolunm_name1,colunm_name2
fromtable_name1
leftjointable_name2
ontable_name1.colunmname=table_name2.colunmname其中join_table指出參與連接操作的表名,連接可以對同一個表操作,也可以對多表操作,對同一個表操作的連接稱為自連接, join_type 為連接類型,可以是left join 或者right join 或者inner join 。
on (join_condition)用來指連接條件,它由被連接表中的列和比較運算符、邏輯運算符等構成。
『柒』 sql server中的一對一、多對一、多對多關系是什麼意思
拿你的學號,和課程來說吧。你和你的學號就是一對一的關系,因為一個學生只有一個學號(當然只同一階段);
你和你的課程是一對多的關系 ,你一個人可以學很多門課程吧。課程和學生就是多對多的關系,一個學生可以學多門課程,而一門課程也會有很多名學生學習。簡單就是這么理解
『捌』 誰能通俗易懂的跟我講下SQL多對多的關系。
幾對幾的關系只有在概念模型里有,概念模型就是E(實體)-R(關系)模型
其中多對多就是,相聯系的兩個實體,在某關系下互相一對多。
比如:選課關系裡的課程和學生。
一個 學生可以 選 多門 課程(1:N)
一門 課程也可 被 多個 學生 選(1:N)
所以 實體學生(選課關系)課程實體 就是多對多的關系(M:N)
而實體教師 (講課關系)課程實體就是一對多,你自己理解一下。