#sql-server-2005 #tsql
#sql-server-2005 #tsql
Вопрос:
Я создаю представление из нескольких таблиц. Каждая включаемая таблица имеет столбец с именем Contact_ID. Я использую MS SQL 2005. Я вижу, что могу использовать DISTINCT для возврата уникального набора по Contact_ID, но тогда в моем представлении отображается только Contact_ID.
Мне нужно, чтобы представление содержало больше, чем просто Contact_ID, поэтому мне нужно создать инструкцию SELECT со всеми правильными столбцами, но у меня не может быть повторяющихся записей.
Вот что у меня есть на данный момент: (Это возвращает все данные, которые мне нужны, но содержит записи с дубликатами Contact_ID)
SELECT dbo.[1_MAIN - Contacts].Contact_ID, dbo.[1_MAIN - Contacts].Date_entered_into_Database, dbo.[1_MAIN - Contacts].Date_of_Initial_Contact,
dbo.[1_MAIN - Contacts].[Company_ Name], dbo.[1_MAIN - Contacts].Key_Contact_Title, dbo.[1_MAIN - Contacts].Key_Contact_First_Name,
dbo.[1_MAIN - Contacts].Key_Contact_Middle, dbo.[1_MAIN - Contacts].Key_Contact_Last_Name, dbo.[1_MAIN - Contacts].Key_Credential,
dbo.[1_MAIN - Contacts].Key_Contact_Occupation, dbo.[1_MAIN - Contacts].Key_Degree_1, dbo.[1_MAIN - Contacts].Key_Degree_2,
dbo.[1_MAIN - Contacts].Key_Degree_3, dbo.[1_MAIN - Contacts].Date_of_Highest_Degree, dbo.[1_MAIN - Contacts].Work_Setting,
dbo.[1_MAIN - Contacts].Website_Address, dbo.[1_MAIN - Contacts].Email_1_Key_Contact, dbo.[1_MAIN - Contacts].Email_2,
dbo.[1_MAIN - Contacts].Email_3, dbo.[1_MAIN - Contacts].Day_Time_Phone_Number, dbo.[1_MAIN - Contacts].Extension,
dbo.[1_MAIN - Contacts].Mobile_Phone_Number, dbo.[1_MAIN - Contacts].Bus_Fax_Number, dbo.[1_MAIN - Contacts].Home_Phone_Number,
dbo.[1_MAIN - Contacts].Home_Fax_Number, dbo.[1_MAIN - Contacts].Mailing_Street_1, dbo.[1_MAIN - Contacts].Mailing_Street_2,
dbo.[1_MAIN - Contacts].Mailing_City, dbo.[1_MAIN - Contacts].Mailing_State, dbo.[1_MAIN - Contacts].[Mailing_Zip/Postal],
dbo.[1_MAIN - Contacts].Mailing_Country, dbo.[1_MAIN - Contacts].[Bad_Address?], dbo.[1_MAIN - Contacts].[PROV/REG?],
dbo.[1_MAIN - Contacts].status_flag, dbo.[1_MAIN - Contacts].status_flag AS status_flag2, dbo.Providers.Contact_ID AS Expr1,
dbo.Providers.Referral_Source, dbo.Resource_Center.access, dbo.Referral.Contact_Source, dbo.Resource_Center.cert_start_date,
dbo.Resource_Center.cert_exp_date, dbo.prov_training_records.Contact_ID AS Expr2, dbo.prov_training_records.date_reg_email_sent
FROM dbo.[1_MAIN - Contacts] INNER JOIN
dbo.Referral ON dbo.[1_MAIN - Contacts].Contact_ID = dbo.Referral.Referral_ID INNER JOIN
dbo.prov_training_records ON dbo.[1_MAIN - Contacts].Contact_ID = dbo.prov_training_records.Contact_ID LEFT OUTER JOIN
dbo.Resource_Center ON dbo.[1_MAIN - Contacts].Contact_ID = dbo.Resource_Center.Contact_ID FULL OUTER JOIN
dbo.Providers ON dbo.[1_MAIN - Contacts].Contact_ID = dbo.Providers.Contact_ID
Тот же запрос с псевдонимами имен таблиц:
SELECT c.Contact_ID, c.Date_entered_into_Database, c.Date_of_Initial_Contact,
c.[Company_ Name], c.Key_Contact_Title, c.Key_Contact_First_Name,
c.Key_Contact_Middle, c.Key_Contact_Last_Name, c.Key_Credential,
c.Key_Contact_Occupation, c.Key_Degree_1, c.Key_Degree_2,
c.Key_Degree_3, c.Date_of_Highest_Degree, c.Work_Setting,
c.Website_Address, c.Email_1_Key_Contact, c.Email_2,
c.Email_3, c.Day_Time_Phone_Number, c.Extension,
c.Mobile_Phone_Number, c.Bus_Fax_Number, c.Home_Phone_Number,
c.Home_Fax_Number, c.Mailing_Street_1, c.Mailing_Street_2,
c.Mailing_City, c.Mailing_State, c.[Mailing_Zip/Postal],
c.Mailing_Country, c.[Bad_Address?], c.[PROV/REG?],
c.status_flag, c.status_flag AS status_flag2, p.Contact_ID AS Expr1,
p.Referral_Source, rc.access, r.Contact_Source, rc.cert_start_date,
rc.cert_exp_date, tr.Contact_ID AS Expr2, tr.date_reg_email_sent
FROM dbo.[1_MAIN - Contacts] c INNER JOIN
dbo.Referral r ON c.Contact_ID = r.Referral_ID INNER JOIN
dbo.prov_training_records tr ON c.Contact_ID = tr.Contact_ID LEFT OUTER JOIN
dbo.Resource_Center rc ON c.Contact_ID = rc.Contact_ID FULL OUTER JOIN
dbo.Providers p ON c.Contact_ID = p.Contact_ID
Ответ №1:
WITH q AS
(
SELECT *,
ROW_NUMBER() OVER (PARTITION BY dbo.[1_MAIN - Contacts].Contact_ID ORDER BY dbo.[1_MAIN - Contacts].Contact_ID) AS rn
FROM dbo.[1_MAIN - Contacts]
INNER JOIN
dbo.Referral
ON dbo.[1_MAIN - Contacts].Contact_ID = dbo.Referral.Referral_ID
INNER JOIN
dbo.prov_training_records
ON dbo.[1_MAIN - Contacts].Contact_ID = dbo.prov_training_records.Contact_ID
LEFT OUTER JOIN
dbo.Resource_Center
ON dbo.[1_MAIN - Contacts].Contact_ID = dbo.Resource_Center.Contact_ID
FULL OUTER JOIN
dbo.Providers
ON dbo.[1_MAIN - Contacts].Contact_ID = dbo.Providers.Contact_ID
)
SELECT *
FROM q
WHERE rn = 1
Комментарии:
1. Я получаю сообщение об ошибке: «Конструкция или оператор OVER SQL не поддерживается».
2. @Dale: что возвращает этот запрос:
select compatibility_level from sys.databases where name = db_name()
?3. Также смотрите ветку комментариев под ответом SQLMenace об использовании MAX (однако это не является обязательным требованием для этого вопроса. Я планировал создать новый вопрос для этой части)
4. @Dale: используете ли вы
Management Studio
для выполнения запроса?5. @Dale: не могли бы вы, пожалуйста, опубликовать точное сообщение об ошибке:
Msg *, Level *
и т.д.?
Ответ №2:
Изначально неправильно истолковал вопрос, вам нужно будет сгруппировать все данные, но если вы хотите отобразить все данные и есть уникальные, вам нужно использовать min или max в некоторых случаях, если у кого-то есть 2 телефона…что вы хотите показать?
Комментарии:
1. Точно, если запись имеет значение в столбце «Contact_Source», я хотел бы использовать эту запись вместо той, которая равна NULL.
2. в этом случае используйте GROUP by и MAX
3. Хм, кажется, не могу понять это правильно. Как бы я использовал GROUP BY и MAX в моем примере?