|
if() в mysql
|
|||
---|---|---|---|
#18+
Из фокса на mysql выполняю select с if(): select if(id<1000, 1100+id, id) as id from tbl Ожидаю получить поле цифрового типа, т.к. tbl.id - цифровое, но получаю символьное. Можете подсказать в чем дело? ... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 00:47 |
|
if() в mysql
|
|||
---|---|---|---|
#18+
vitkvit, а так: Код: plaintext 1.
может мускул тебе bigint возвращает без cast. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 09:22 |
|
if() в mysql
|
|||
---|---|---|---|
#18+
WORKSNS, с cast-ом тоже пробовал, не помогает. Пробовал вставлять abs() - результат тот же. Код: plaintext
Код: plaintext
... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 09:35 |
|
if() в mysql
|
|||
---|---|---|---|
#18+
igorbik IIF() ответ не правильный ... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 10:24 |
|
if() в mysql
|
|||
---|---|---|---|
#18+
vitkvitWORKSNS, с cast-ом тоже пробовал, не помогает. Пробовал вставлять abs() - результат тот же. Код: plaintext
Код: plaintext
а у id поля какой тип данных? ... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 11:12 |
|
if() в mysql
|
|||
---|---|---|---|
#18+
WORKSNS, int, естественно ... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 11:29 |
|
if() в mysql
|
|||
---|---|---|---|
#18+
vitkvit, похоже заложено в стандарте SQL Сейчас попробовал на FB Код: plaintext
Код: plaintext
Не понятно почему MySql при явном cast всего выражения в итоге отдает bigint. Может какая-то особенность версии сервера/драйвера. C MySQL практически не общался к сожалению. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 11:38 |
|
if() в mysql
|
|||
---|---|---|---|
#18+
vitkvit, единственное, чем это можно побороть - использовать курсорадаптеры (с прописанной схемой курсора, естественно), по кр. мере, я иного способа не нашёл. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 11:50 |
|
if() в mysql
|
|||
---|---|---|---|
#18+
6.3.3 Числовые функции 6.3.3.1 Арифметические операции В MySQL можно применять обычные арифметические операторы. Следует иметь в виду, что если оба аргумента являются целыми числами, то при использовании операторов `-', `+' и `*' результат вычисляется с точностью BIGINT (64 бита). Если один из аргументов - беззнаковое целое число, а второй аргумент - также целое число, то результат будет беззнаковым целым числом. See section 6.3.5 Функции приведения типов. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.06.2011, 11:52 |
|
|
start [/forum/topic.php?fid=41&fpage=74&tid=1584334]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
39ms |
get topic data: |
14ms |
get forum data: |
3ms |
get page messages: |
52ms |
get tp. blocked users: |
2ms |
others: | 321ms |
total: | 463ms |
0 / 0 |