0

我有两张表,一张在我当前的系统中有当前的电子邮件,一张是我创建并从全球通讯簿中导出的所有电子邮件地址,以及一个 BIT 值,它是主电子邮件地址和用户 ID 值. 我使用子查询编写了一个查询来查找应该更改哪些电子邮件地址,但我虽然应该能够在不使用子查询的情况下做到这一点,但不知道怎么做?

有谁知道不使用子查询如何或是否可以做得更好?

我有什么工作,但我想学习如何更好地编写 SQL。

我虽然应该能够使用 OVER (Partition BY Member_ID) 和 MAX(CAST( [primary] AS int)) 来做到这一点,但花了几个小时试图弄清楚并没有成功。

User_Emails
{
email varchar(75)
}

eg:
User_Emails
bob@oldemail.com
sue@evenolderemail.com
jim@otheremail.com
bill@oldemail.com

...

Global_Address_Book
{
Member_ID int
primary BIT
email_address varchar(75)
}

eg:
Member_ID        | primary | email_address
1                | 1       | bob@newemail.com
1                | 0       | bob@reallyoldemail.org
1                | 0       | bob@oldemail.com
2                | 1       | sue@newemail.com
2                | 0       | sue@oldemail.com
2                | 0       | sue@reallyoldemail.org
2                | 0       | sue@evenolderemail.com
3                | 1       | bill@newemail.com
3                | 0       | bill@oldemail.com
4                | 1       | jan@alternativeemail.com

...

SELECT Changed_Email_list.email AS Old_Email, New_Email_List.email_address AS New_Email
FROM (SELECT Member_ID, email
      FROM [Database].[Global_Address_Book] INNER JOIN [Database].[User_Emails]
       ON [Global_Address_Book].[email_address] = [User_Emails].[email]) AS     
      Changed_Email_list LEFT JOIN 
      (SELECT Member_ID, email_address 
       FROM [Database].[Global_Address_Book]
       WHERE [primary] = 1) AS New_Email_List
       ON Changed_Email_list.Member_ID = New_Email_List.Member_ID
4

1 回答 1

2

我猜应该这样做

select UserEmails.Email as OldEmail,GAB.Email as NewEamil
from   UserEmailsfromAddressBook  
inner join UserEmails on UserEmails.Email=UserEmailsfromAddressBook.Email
      and isprimary =0
inner join UserEmailsfromAddressBook  GAB on GAB.memberId=UserEmailsfromAddressBook.memberID
     and GAB.isprimary=1

sqlfiddle中的测试脚本

于 2012-09-03T23:19:57.393 回答