Loading...
nick.genov avatar nick.genov 104 Точки

Problem 9. Rivers by Country - Databases Exam (March 2015) - Решение

Здравейте, колеги.

Срещам затруднения при получаването на точки в Judge за тази задача. Тук съм сложил условието, моето решение и авторското решение: http://pastebin.com/yhSQzYnQ

С изненада установих, че резултатите от моето и авторското решение са идентични (сравнявах ги в diffchecker). Усъмних се да не съм променил базата, изтрих я и я създадох наново със скрипта към изпита. Отново 0 точки.

Интересното е, че и при събмит на резултата от авторския селект пак имам 0 точки.

Къде е проблема?

 

Тагове:
0
Databases Basics 20/06/2015 13:12:16
infreezer avatar infreezer 15 Точки

Здравей, колега.

И аз имам същия проблем на 3та, 9та и 12та задача от този изпит. Не виждам друг вариант освен условието и авторското решение да са грешни или тестовете в Judge. Някой имал ли е успех с тези задачи ?

1
RoYaL avatar RoYaL Trainer 6849 Точки

На този изпит имаше няколко проблема, повечето бяха свързани с ORDER-а. Аз лично пробвах на всяка задача да сложа ASC, DESC или да не пиша нищо след ORDER BY и при някоя от всичките комбинации ставаше.

В тази задача до колкото си спомням трябваше държавите експлицитно да се ордернат ASCENDING.

Това е моето решение на задачата по време на изпита:

SELECT
    c.CountryName,
    cn.ContinentName,
    ISNULL(COUNT(r.Id), 0) RiversCount,
    ISNULL(SUM(r.Length), 0) TotalLength
FROM
    Countries c
INNER JOIN
    Continents cn
ON
    c.ContinentCode = cn.ContinentCode
LEFT JOIN
    CountriesRivers cr
ON
    c.CountryCode = cr.CountryCode
LEFT JOIN
    Rivers r
ON
    cr.RiverId = r.Id
GROUP BY
    c.CountryName,
    c.CountryCode,
    cn.ContinentName
ORDER BY
    ISNULL(COUNT(r.Id), 0) DESC,
    ISNULL(SUM(r.Length), 0) DESC,
    c.CountryName ASC

 

Предполагам при 12та задача е било същото, защото и там експлицитно съм сложил ORDER BY ... ASC на държавите. Не е ясно колко са последните куерита, от които съм изкарал резултатите, тези които съм качил в системата де, но мисля че са работещи. Та, на 12та order-a:

ORDER BY
    ISNULL(MAX(p.Elevation), 0) DESC,
    ISNULL(MAX(r.Length), 0) DESC,
    c.CountryName ASC

P.S.: Това е аутпутът, който вадя на 9та задача, сравнете го с вашия да видим къде са грешките? ( http://pastebin.com/JwszJF8x ) тъй като по документация дали ще напишеш ASC или няма уж е без значение

1
20/06/2015 19:53:42
infreezer avatar infreezer 15 Точки

Благодаря за бързия отговор. Ето ги разликите

След като смених CountryName на nvarchar от varchar, заспа и всичко тръгна перфектно. Това грешка в скрипта ли е или уловка.

1
22/06/2015 23:36:01
RoYaL avatar RoYaL Trainer 6849 Точки

Може би е по-скоро проблем на различните версии на SQL Server. Оправя се и като при правене на базата сложиш COLLATION. По някаква причина на някои версии на SQL Server не е по дефолт unicode и съответно специалните символи (като А умлаут) не излизат правилно. На мен например по дефолт си ми се импорват в базата както трябва, но се оказа че при някои хора - не.

Хубаво е иначе винаги да се работи с unicode, така че nvarchar почти винаги е по-добро решение от varchar.

1
infreezer avatar infreezer 15 Точки

Би ли ми казал какъв ти е collation-а на базата. На мен ми е Cyrillic_General_CI_AS.

0
RoYaL avatar RoYaL Trainer 6849 Точки

Различен е: SQL_Latin1_General_CP1_CI_AS

2
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.