powered by simpleCommunicator - 2.0.53     © 2025 Programmizd 02
Форумы / Firebird, InterBase [игнор отключен] [закрыт для гостей] / С чем связана такая дискриминация BOOLEAN?
24 сообщений из 24, страница 1 из 1
С чем связана такая дискриминация BOOLEAN?
    #39199334
afgm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Все условно-неявные конвертации выполняются отлично. Кроме boolean.
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
select '' || cast( 1 as SMALLINT ) from rdb$database;
select '' || cast( 1 as INTEGER ) from rdb$database;
select '' || cast( 1 as BIGINT ) from rdb$database;
select '' || cast( TRUE as BOOLEAN ) from rdb$database; -- Overflow occurred during data type conversion.
                                                        -- conversion error from string "BOOLEAN".
select '' || cast( 1.1 as FLOAT ) from rdb$database;
select '' || cast( 1.1 as DOUBLE PRECISION ) from rdb$database;
select '' || cast( 1.1 as NUMERIC(3,3) ) from rdb$database;
select '' || cast( 1.1 as DECIMAL(3,3) ) from rdb$database;
select '' || cast( '2015-01-01' as DATE ) from rdb$database;
select '' || cast( '10:51:59' as TIME ) from rdb$database;
select '' || cast( '2015-01-01 10:51:59' as TIMESTAMP ) from rdb$database;
select '' || cast( 'char text' as CHAR(20) ) from rdb$database;
select '' || cast( 'varchar text' as VARCHAR(20) ) from rdb$database;
select '' || cast( 'blob text' as BLOB ) from rdb$database;


А вот так нормально:
Код: sql
1.
select cast( TRUE as varchar(20) ) from rdb$database;
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39199507
dimitr
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
я не уверен, что в реальной жизни кому-то нужно делать CAST(TRUE AS BOOLEAN). Но можешь попробовать занести в трекер.
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39199622
afgm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dimitrя не уверен, что в реальной жизни кому-то нужно делать CAST(TRUE AS BOOLEAN). Но можешь попробовать занести в трекер.
Тут для того, что бы не было вопросов по поводу типа. ''||TRUE тоже не пашет.
CORE-5167
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39203327
afgm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Адриано закрыл таки с формулировкой: "Boolean is not implicit convertable to string, so it should not work with concatenation."
Так и не понял почему. Ну он мудрей, ему видней.
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39203559
dimitr
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
патамучта он так решил :-) Давным-давно, насколько я помню. И это даже обсуждалось. Если есть желание поспорить - пишите в трекер аргументы. Лучше ссылки на стандарт и на другие СУБД.
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39203574
MaratIsk
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
afgm,

потому что число, строка, дата - материальные сущности и имеют конкретное отражение
а boolean - понятийное явление - правда/неправда, 0/1 и отражается опосредованно - словами или числами
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39203984
Мимопроходящий
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Hello, Maratisk!
You wrote on 30 марта 2016 г. 12:04:29:

Maratisk> а boolean - понятийное явлениене нужно отсебятины.
есть стандарт.

Posted via ActualForum NNTP Server 1.5
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204207
MaratIsk
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Модератор: Предупреждение.

И кстати, рассказывать, что число, строка и дата имеет материальное отражение, а boolean нет - это в ветку "Юмор". Там оценят.
Хех, материальное.
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204276
afgm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
dimitrЛучше ссылки на стандарт и на другие СУБД.
Как мог ответил. Про СУБД не стал. Из других СУБД только PG, там всё склеивается. MSSQL только битовый тип. MySql как ориентир.... сомнительно. Оракла под рукой нет.
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204286
Мимопроходящий
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Hello, Afgm!
You wrote on 30 марта 2016 г. 16:00:03:

Afgm> Оракла под рукой нет.у Оракла тру-булеан есть только в PL-SQL.
в чистом SQL его нет.
(правда, за новые версии не уверен)

Posted via ActualForum NNTP Server 1.5
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204298
Фотография kdv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Мимопроходящий,

https://docs.oracle.com/javadb/10.8.3.0/ref/rrefsqlj33562.html
A BOOLEAN value can be cast explicitly to any of the string types. The result is 'true', 'false', or null. Conversely, string types can be cast to BOOLEAN.

Впрочем, лично я вижу смысл в конвертации boolean в строку только для англоязычных пользователей. Ну или для импорта/экспорта данных, которые содержат true/false в строковом виде.
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204314
Мимопроходящий
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Hello, Kdv!
You wrote on 30 марта 2016 г. 16:19:14:

Kdv> https://docs.oracle.com/ javadb/10.8.3.0/ref/rrefsqlj33562.html
Дмитрий, ну ЁКЛМН!
ты всё ж таки смотри куда пальцем тыкаешь...
Posted via ActualForum NNTP Server 1.5
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204328
afgm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Не убедил я Адриано.
Всегда воспринимал || как избавление от нагромождения cast-ов к varchar-ам с размерами при склейке строк. Там и coalesce есть где пописать.
Вот в MSSQL достаёт порой. Благо в 2012 таки ввели функцию concat.
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204342
Фотография kdv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Мимопроходящийты всё ж таки смотри куда пальцем тыкаешь...
я уже потом javadb в ссылке углядел. Тем не менее - Оракл? Оракл. Каст boolean в строку есть? Есть. :-)

Собственно, я не понимаю, чего Адриано так убивается по этому поводу. Либо это пуризм, либо нет согласия в стане СУБД.
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204352
Мимопроходящий
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Hello, Kdv!
You wrote on 30 марта 2016 г. 16:51:39:

Kdv> я уже потом javadb в ссылке углядел. Тем не менее - Оракл? Оракл. не всё то оракал шо рождено от жабы ;)
но как тынц в сторону Адриано таки наверное прокатит,
ибо поциент был замечен в злоупотреблении жабой.
Kdv> Собственно, я не понимаю, чего Адриано так убивается по этому поводу.
> Либо это пуризм, либо нет согласия в стане СУБД.это не пуризм.
это сильно затянувшийся пубертатный период...
Posted via ActualForum NNTP Server 1.5
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204473
Arioch
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
afgm Оракла под рукой нет.

есть!

http://sqlfiddle.com/
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204479
Arioch
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
kdvсмысл в конвертации boolean в строку только для англоязычных пользователей.

вот с этим я лично тоже согласен

нужно перекодирование зависящее от языка соединения, например.
или от языка запроса

cast (boolean_column as varchar(10) collate xyz)

есть ли такое готовое в ICU - хз
если нет, то готовить переводы для всех языков силами FB team - стрёмно

Сделать настройку через RDB$SET_CONTEXT ? так не сохраняется....

----------

но с дргой стороны, при преоразовании в строку/из строки дат, времени и дробных чисел - ведь никто не учитывает языки, наоборот все ориентируются на какой-то древний времен Groton американский стандарт, и не жужжат, привыкли
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204493
Фотография kdv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Ariochесть ли такое готовое в ICU - хз
ты опять покурил? :-) какой, нафиг, словарь в icu?
Ariochесли нет, то готовить переводы для всех языков силами FB team - стрёмно
госсподи... какие еще переводы...

select cast(1 as varchar(20))
'адын'
так, что-ли? :-)
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204513
afgm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Ariochесть!

http://sqlfiddle.com/
Давно пробовал? Я не дождался ответа от сервера :)
Единственное, что нашёл http://sqlzoo.net/
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204527
Arioch
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
kdv,

прочитированное - было конкретно про boolean
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204529
Arioch
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
kdv,

а вообще - хочется то ли нкруитсья ,то ли напиться, хреновый был день сегодня и суматошный.

но это, если ты меня замечаешь по запаху - статью уже поправь наконец

18974399
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204540
Фотография DarkMaster
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Arioch,

Присоединяюсь. Меня тоже немцы з... мучили вконец. Где встречаемся?
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39204892
Мимопроходящий
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Hello, Arioch!
You wrote on 31 марта 2016 г. 11:15:01:

Arioch> нужно перекодирование зависящее от языка соединения, например.
> или от языка запроса
>
> cast (boolean_column as varchar(10) collate xyz)
предлагаю еврейский вариант:
Код: sql
1.
2.
cast (TRUE as varchar(10) collate ISO8859_8_RU) == 'таки да, а шо?'
cast (FALSE as varchar(10) collate ISO8859_8_RU) == 'не, ну а шо?'


Posted via ActualForum NNTP Server 1.5
...
Рейтинг: 0 / 0
С чем связана такая дискриминация BOOLEAN?
    #39205037
WildSery
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Мимопроходящий,

VARCHAR(14) только.
...
Рейтинг: 0 / 0
24 сообщений из 24, страница 1 из 1
Форумы / Firebird, InterBase [игнор отключен] [закрыт для гостей] / С чем связана такая дискриминация BOOLEAN?
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]