[英]Sql Inner Join with distinct values
我有3張桌子:
我必須使用內部聯接來聯接這3個表。
在銀行轉帳中,我有一列Number
,並且在“受益人和回撥”表中重復該Number
。
在“ Beneficiaries
表中,該數字可以重復多次。
運行內部聯接查詢時,得到的結果多於1個,而不是唯一的值。
在“ Beneficiaries
表中,我還有一列Beneficial_Name
,並且此列唯一地標識結果,但是在運行聯接查詢時,會得到重復的結果。
我嘗試了不同的選擇,但效果並不理想。
以下是我的代碼-有人可以幫幫我嗎?
SELECT DISTINCT
dbo.BT_Beneficiaries.Beneficial_Name,
dbo.Bank_Transfer.Number, dbo.Bank_Transfer.Start_Date,
dbo.Bank_Transfer.Team_Name, dbo.Bank_Transfer.Initiator,
dbo.Bank_Transfer.Staff, dbo.Bank_Transfer.Process_Name,
dbo.Bank_Transfer.Company_Name, dbo.Bank_Transfer.Billing_Amount,
dbo.Bank_Transfer.Entry_ID, dbo.Bank_Transfer.Instructions,
dbo.Bank_Transfer.BT_Count, dbo.Bank_Transfer.Misspelled,
dbo.Bank_Transfer.Sender, dbo.Bank_Transfer.Odd,
dbo.Bank_Transfer.Email, dbo.Bank_Transfer.Beneficiary,
dbo.Bank_Transfer.Address, dbo.Bank_Transfer.Urgent,
dbo.Bank_Transfer.Payment, dbo.Bank_Transfer.Sperry,
dbo.Bank_Transfer.Contact, dbo.Bank_Transfer.Reasonable,
dbo.Bank_Transfer.Evidence_Completed, dbo.Bank_Transfer.End_Date,
dbo.Bank_Transfer.First_Mgr_Approval_Name, dbo.Bank_Transfer.First_Mgr_Approval,
dbo.Bank_Transfer.First_Mgr_Approval_Date, dbo.Bank_Transfer.CallBack_Workings,
dbo.Bank_Transfer.CallBack_Agreement, dbo.Bank_Transfer.CallBack_Procedure,
dbo.Bank_Transfer.Second_Mgr_Approval_Name, dbo.Bank_Transfer.Second_Mgr_Approval,
dbo.Bank_Transfer.Second_Mgr_Approval_Date, dbo.Bank_Transfer.IB,
dbo.Bank_Transfer.IB_Date, dbo.Bank_Transfer.ITL_Signatory_Approval,
dbo.Bank_Transfer.ITL_Signatory_Name,
dbo.BT_Beneficiaries.Account_Number, dbo.BT_Beneficiaries.Currency,
dbo.BT_Beneficiaries.Payment_Details, dbo.BT_Beneficiaries.CurrencyPayment,
dbo.BT_Beneficiaries.Amount, dbo.BT_Beneficiaries.Purpose,
dbo.BT_Beneficiaries.Evidence, dbo.BT_Beneficiaries.Due_Diligence,
dbo.BT_Beneficiaries.WC, dbo.BT_Beneficiaries.Resolution_Directors,
dbo.BT_Beneficiaries.Manager_Approval, dbo.BT_Beneficiaries.Mgr_Approval_Date,
dbo.CB_BankAccount.Number AS Expr3, dbo.CB_BankAccount.Company_Name AS Expr4,
dbo.CB_BankAccount.Bank_Name, dbo.CB_BankAccount.Bank_Account,
dbo.CB_BankAccount.Currency AS Expr5, dbo.CB_BankAccount.Balance,
dbo.CB_BankAccount.Bank_Mandate, dbo.CB_BankAccount.Signing_Arrangement AS Expr6,
dbo.CB_CallBack_Procedure.Number AS Expr8, dbo.CB_CallBack_Procedure.CallStatus,
dbo.CB_CallBack_Procedure.Person_CalledBack, dbo.CB_CallBack_Procedure.DateTime,
dbo.CB_CallBack_Procedure.Notes, dbo.CB_CallBack_Procedure.Mgr_Approval,
dbo.CB_CallBack_Procedure.DateTime_Approval, dbo.CB_CallBack_Procedure.Bank_DateTime
FROM
dbo.Bank_Transfer
INNER JOIN
dbo.BT_Beneficiaries ON dbo.Bank_Transfer.Number = dbo.BT_Beneficiaries.Number
INNER JOIN
dbo.CB_BankAccount ON dbo.BT_Beneficiaries.Number = dbo.CB_BankAccount.BT_Number
INNER JOIN
dbo.CB_CallBack_Procedure ON dbo.CB_BankAccount.BT_Number = dbo.CB_CallBack_Procedure.Number
只需添加一個WHERE子句,它指定識別唯一記錄所需的Benficial_Name列:
WHERE Beneficiaries = 'Unique Record'
編輯此內容以說出所需內容。 您可以在加入后放置它。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.