Loading...

Във форума е въведено ограничение, което позволява на потребителите единствено да разглеждат публикуваните въпроси.

abetterman avatar abetterman 21 Точки

Exercises: Functions, Triggers and Transactions - задача 12.Deposit Money

Защо ми дава само 40 точки в judge? Какво ли не пробвах.

CREATE PROCEDURE usp_deposit_money(a_account_id INT(11), money_amount DECIMAL(65,4))
BEGIN
START TRANSACTION;
IF(money_amount<=0 OR money_amount IS NULL OR a_account_id IS NULL OR a_account_id<1) THEN ROLLBACK;
ELSE
UPDATE accounts
SET balance = balance + money_amount
WHERE id = a_account_id;
END IF;
END

0
Databases Basics - MySQL 14/10/2018 13:13:23
k.sevov avatar k.sevov 1077 Точки

Джъдж не работи особено добре в момента, тъй като сигурно има изпити и не мога да тествам, но ето тук има решение да си сравниш и да пробваш какво ще го оправи. 

0
abetterman avatar abetterman 21 Точки

ами и твоето решение дава 40 точки

0
k.sevov avatar k.sevov 1077 Точки

Сигурно са сменили нещо по тестовете в такъв случай, беше си 100/100 в предното издание на курса...

0
abetterman avatar abetterman 21 Точки

Може би в тези две изречения се крие отговора.
Make sure to guarantee valid positive money_amount with precision up to fourth sign after decimal point. The procedure should produce exact results working with the specified precision.

Има ли начин да се проверява дали подаденото число е до точно 4тири знака след десетичната запетая?

0
D.Dimov_96 avatar D.Dimov_96 74 Точки

Моето решение получава 60/100 :https://github.com/DimovDimo/Software-University-SoftUni/blob/master/Java-DB-September-2018/Database-Basics-MySQL-September-2018/16%2CDatabase%20Programmability%20-%20Exercise/Work/PART%20II%20%E2%80%93%20Queries%20for%20Bank%20Database/12.%20Deposit%20Money.sql

Не можах да изкарам 100/100

За да вземем количеството знаци след запетаята, можем да използваме:

IF(money_amount = floor(money_amount), 0, char_length(money_amount - floor(money_amount))- 2)

Проверяваме дали числото е цяло. Ако да, връщаме 0 знака. В друг случай взимаме дължината на стринга, който се получава от разликата на числото с неговата закръглена надолу стойност. После вадим 2, защото всеки подобен стринг започва с '0.', а това има дължина 2. Резултата е количеството знаци след запетаята.

0
TeodorStefanovPld avatar TeodorStefanovPld 1274 Точки

не че нещо ама каква е тая тъпотия? ще проверяваш стринга и тн ?

като имаш Decimal(18,4) примерно и това ти осигурява 4те знака.

По-скоро е от тестовете в judge нещо се е променило в последните ъпдейти на Mysql а те не са ъпдейтнати,най-вероятно.и от там идва разминаването. Иначе имам подобно на колегата Севов решение и аз карах mysql миналия октомври.

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