Boolean тип sql: PostgreSQL : Документация: 9.5: 8.6. Логический тип : Компания Postgres Professional

Типы данных языка запросов SQLite

  1. Главная

  2. Туториалы

  3. Базы данных

  4. SQLite

Тип данных SQLite — это атрибут, определяющий тип данных любого объекта. Каждый столбец, переменная и выражение имеет связанный тип данных в SQLite.

Вы будете использовать эти типы данных при создании своих таблиц. SQLite использует более общую систему динамического типа. В SQLite тип данных значения связан с самим значением, а не с его контейнером.

Классы хранения SQLite

Каждое значение, хранящееся в базе данных SQLite, имеет один из следующих классов хранения







НазваниеОписание
NULLЗначение — значение NULL.
INTEGERЗначение представляет собой целое число со знаком, сохраненное в 1, 2, 3, 4, 6 или 8 байтах в зависимости от величины значения.
REALЗначение представляет собой значение с плавающей запятой, которое хранится как 8-байтовое число с плавающей точкой IEEE.
TEXTЗначение представляет собой текстовую строку, хранящуюся с использованием кодировки базы данных (UTF-8, UTF-16BE или UTF-16LE)
BLOBЗначение представляет собой блок данных, который хранится точно так же, как он был введен.

Тип слияния SQLite

SQLite поддерживает концепцию affinity (близость) типа к столбцам. Любой столбец может хранить данные любого типа, но предпочтительный класс хранения для столбца называется affinity. Каждому столбцу таблицы в базе данных SQLite3 присваивается одно из следующих аффинностей типа:







НазваниеОписание
TEXTВ этом столбце хранятся все данные с использованием классов хранения NULL, TEXT или BLOB.
NUMERICЭтот столбец может содержать значения, используя все пять классов хранения.
INTEGERРаботает так же, как столбец с NUMERIC сродством, с исключением в выражении CAST.
REALВедет себя как столбец с NUMERIC сродством, за исключением того, что он приводит целые значения в представление с плавающей запятой.
NONEСтолбец с аффинностью NONE не предпочитает один класс хранения над другим, и не предпринимаются попытки принудить данные из одного класса хранения к другому.

Идентификация и имена типов SQLite

В следующих списках таблиц перечислены имена типов данных, которые можно использовать при создании таблиц SQLite3 с соответствующим применимым сродством.







ТипБлизость

  • INT
  • INTEGER
  • TINYINT
  • SMALLINT
  • MEDIUMINT
  • BIGINT
  • UNSIGNED BIG INT
  • INT2
  • INT8
INTEGER

  • CHARACTER(20)
  • VARCHAR(255)
  • VARYING CHARACTER(255)
  • NCHAR(55)
  • NATIVE CHARACTER(70)
  • NVARCHAR(100)
  • TEXT
  • CLOB
TEXT

  • BLOB
  • no datatype specified
NONE

  • REAL
  • DOUBLE
  • DOUBLE PRECISION
  • FLOAT
REAL

  • NUMERIC
  • DECIMAL(10,5)
  • BOOLEAN
  • DATE
  • DATETIME
NUMERIC

Boolean Тип данных

SQLite не имеет отдельного булевского класса хранения.  Вместо этого булевые значения сохраняются как целые числа 0 (ложь) и 1 (истина).

Тип данных даты и времени

SQLite не имеет отдельного класса хранения для хранения дат и / или времени, но SQLite способен хранить даты и время как значения TEXT, REAL или INTEGER.





НазваниеОписание
TEXTДата в формате «YYYY-MM-DD HH:MM:SS.SSS»
REALЧисло дней с полудня в Гринвиче 24 ноября 4714 г. до н.э.
INTEGERКоличество секунд с 1970-01-01 00:00:00 UTC

 

Логические поля в базах данных, есть ли противоядие / Хабр


Часто в таблицах содержится большое количество логических полей, проиндексировать все из них нет возможности, да и эффективность такой индексации низка. Тем не менее, для работы с произвольными логическими выражениями в SQL пригоден механизм многомерной индексации о чем и пойдёт речь под катом.


В SQL логические поля используются в основном в двух случаях. Во-первых, когда действительно нужен бинарный атрибут, например, ‘купля/продажа’ в таблице сделок. Такие атрибуты редко меняются со временем.

Во-вторых, для записи состояния конечного автомата, которым описывается запись. Имеется в виду, что логический объект, соответствующий записи таблицы, проходит ряд состояний, число которых и переходы между которыми определяются прикладной логикой. Простой пример — техника “soft-delete”, когда запись физически не уничтожается, а только помечается как удалённая.

Если автомат сложный, таких полей может быть изрядное количество, в одной из наших таблиц 58 (+14 устаревших) таких полей (включая наборы флагов) и это не что-то из ряда вон выходящее. Так не было задумано изначально, но по мере развития продукта и изменения внешних требований развиваются и соответствующие автоматы, приходят и уходят разработчики, меняются аналитики… в какой-то момент может оказаться безопаснее завести новый флаг, нежели разбираться во всех хитросплетениях. Тем более что накопились исторические данные и их состояния обязаны оставаться адекватными.

оффтоп

Чем-то это похоже на эволюционный процесс, когда в геноме хранится масса информации/механизмов, которые на первый взгляд и не нужны вовсе, но избавиться от них невозможно. С другой стороны, стоит относиться с уважением к этим механизмам, ведь именно они позволили эволюционным предшественникам выжить (в том числе во время великих вымираний) и победить в эволюционной гонке. Опять же, кто знает, куда заведет нас эволюция и что окажется полезным в дальнейшем.


Завести флаг означает не только добавить поле соответствующего типа, но и учесть его в работе автомата, какие состояния оно затрагивает, в каких переходах участвует. На практике это выглядит так:

  • процесс или ряд процессов, назовём их “писателями”, создают новые записи в начальном состоянии (возможно, в одном из начальных состояний)
  • ряд процессов, назовём их “читателями”, время от времени читают объекты, находящиеся в нужных им состояниях
  • ряд процессов, назовём их “обработчиками”, следят за конкретными состояниями и исходя из прикладной логики меняют эти состояния. Т.е. осуществляют деятельность конечного автомата.


Для того чтобы выбрать записи, находящиеся в конкретном состоянии, редко когда достаточно фильтрации по одному из булевых полей. Обычно это целое выражение, иногда нетривиальное. Казалось бы, надо проиндексировать эти поля и SQL-процессор сам разберётся. Но не всё так просто.

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

Во вторых, это может оказаться бесполезным т.к. селективность по каждому из полей будет низкой, а совместная вероятность статистикой SQL-процессора не покрывается.

Пусть, в таблице T1 есть два булевых поля: F1 & F2, а запрос

select F1, F2, count(1) from T1 group by F1, F2


выдаёт






F1F2COUNT
falsefalse499
falsetrue1
truefalse1
truetrue499


Т. е. хотя, по F1 & F2 выпадение true и false равновероятно, сочетание (true,false) выпадает только один раз из тысячи. В результате, если раздельно проиндексировать F1 & F2

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

И даже если собирать статистику по исполненным запросам, толку от нее будет мало т.к. статистика конкретно по полям, отвечающим за состояние автомата очень сильно плавает. Ведь в любой момент может прийти “обработчик” и половину строк из состояния S1 перевести в S2.

Для работы с такими выражениями напрашивается многомерный индекс, алгоритм которого был представлен ранее и неплохо себя зарекомендовал.

Но прежде требуется разобраться каким образом произвольное логическое выражение превратится в запрос(ы) к индексу.

Дизъюнктивная нормальная форма


Единичный запрос к многомерному индексу представляет собой многомерный прямоугольник, ограничивающий пространство запроса. Если поле участвует в запросе, для него задаётся ограничение. Если нет, прямоугольник по этой координате ограничен только разрядностью данной координаты. Логические координаты имеют разрядность 1.

Поисковый запрос в таком индексе является цепочкой из & (конъюнкцией), например, выражение: v1 & v2 & v3 & (!v4), эквивалентно v1:[1,1], v2:[1,1], v3:[1,1], v4:[0,0]. А все остальные поля имеют диапазон: [0,1].

Учитывая это, наш взор сразу обращается в сторону ДНФ — одной из канонических форм логических выражений. Утверждается, что любое выражение может быть представлено к виду дизъюнкции конъюнкций литералов. Под литералом здесь понимается логическое поле или его отрицание.

Иными словами, путём нехитрых манипуляций, любое логическое выражение может быть представлено в виде дизъюнкции нескольких запросов к многомерному логическому индексу.

Есть и одно НО. Такое преобразование в некоторых случаях может привести к экспоненциальному росту размера выражения. Например, преобразование из

приводит к выражению размером в 2**n термов. В таких случаях прикладному разработчику стоит задуматься о физическом смысле того, что он делает, а со стороны SQL процессора всегда можно отказаться от использования логического индекса, если число конъюнкций превышает пределы разумного.

Алгоритм многомерной индексации


Для многомерной индексации используются свойства самоподобной нумерующей кривой на основе гипер-кубических симплексов со стороной 2. Как оказалось, практическое значение имеют два варианта таких кривых — Z-кривая и кривая Гильберта.

Фиг.1 двумерная Z-кривая, 3 и 6 итерации

Фиг.2 двумерная кривая Гильберта, 3 и 6 итерации

  • N-мерный симплекс со стороной 2 имеет 2**n вершин и (2**n-1) переходов между ними.
  • Элементарная итерация симплекса превращает каждую вершину симплекса в симплекс нижнего уровня.
  • Проделав нужное число итераций, можно построить гипер-кубическую решетку любого размера.
  • При этом каждый узел этой решетки будет иметь свой уникальный номер — путь, проделанный по нумерующей кривой от ее начала. При этом каждый узел этой решетки имеет значение по каждой из координат. Фактически, нумерующая кривая переводит многомерную точку в одномерное значение, пригодное для индексации обычным B-деревом.
  • Все узлы, находящиеся внутри симплекса любого уровня, находятся в пределах одного интервала и этот интервал не пересекается ни с одним симплексом того же уровня.
  • Следовательно, любой поисковый прямоугольник (параллелепипед) может быть разбит на небольшое число гипер-кубических подзапросов, в пределах каждого из которых индекс может быть прочитан одним поиском/траверзом.
  • К этому добавим магию низкоуровневой работы с B-деревом для того, чтобы не делать бесполезные запросы и … алгоритм готов.


Вот как это работает на практике:

Фиг.3 Пример поиска в двумерном индексе (Z-кривая)

На фиг. 3 показано разбиение исходного поискового экстента на подзапросы и найденные при этом точки. Использовался двумерный индекс, построенный на случайном равномерно распределенном наборе 100 000 000 точек в экстенте [1 000 000, 1 000 000].

Логический многомерный индекс


Раз уж речь зашла о многомерном индексировании, самое время задуматься, а насколько многомерным он может быть? Есть ли какие-то объективные ограничения?

Конечно, ведь B-дерево имеет страничную организацию и для того, чтобы быть деревом, на странице должно гарантированно помещаться не менее двух элементов. Если принять страницу за 8К, значит на хранение одного элемента не может уходить больше 4К. В 4К без сжатия влезает около 1000 32-разрядных значений. Это довольно много, выше пределов любого разумного применения, можно сказать, что физические пределы практически не доступны.

Есть и другая сторона, каждое дополнительное измерение отнюдь не бесплатно, на него уходит дисковое пространство и замедляется работа. С точки зрения “физического смысла”, в один индекс должны попадать поля, которые меняются одновременно и поиск по ним тоже идёт совместно. Никакого смысла индексировать всё подряд нет.

С логическими полями всё по другому. Как мы видели, в одних и тех же механизмах могут быть задействованы десятки логических полей. А затраты на хранение/чтение довольно малы. Есть соблазн собрать всё без исключения логические поля в одном индексе и посмотреть что получится.

Правда, есть нюансы:

  • До сих пор в индексируемом значении разряды разных координат перемешивались, в младших разрядах ключа оказывались младшие разряды координат … Поэтому порядок следования полей при индексации не имел значения.
  • Теперь же на хранение значения одного логического поля тратится один разряд. Т.е. какие-то логические поля попадут в конец ключа, а какие-то в начало. А это означает, что фильтрация по части полей будет проходить очень эффективно, а по некоторым очень неэффективно. В самом деле, если мы делаем поиск по самому младшему разряду, придётся прочитать весь индекс чтобы получить ответ. Но это (скорее всего) лучше, чем прочитать всю таблицу, чтобы ответить на тот же вопрос.
  • Возникает проблема выбора — все логические поля равны, но некоторые окажутся равнее прочих. Из общих соображений, необходимо смотреть на перекосы статистики, чем сильнее соотношение true/false для конкретного поля отстоит от равновесного, тем старше должен быть разряд, в котором окажется его значение.
  • Исчезает разбиение по типу нумерующей кривой, если раньше приходилось выбирать между Z-кривой и кривой Гильберта, на одноразрядных данных практической разницы нет.
  • NULL-ы. Если исходить из того, что NULL — это не неизвестное значение, а отсутствие какого бы то ни было значения, то такие записи не должны попадать в индекс. В одномерных индексах так и происходит. Но в нашем случае может оказаться, что часть логических полей содержит значения, а часть нет. В результате мы не можем положить это в индекс т.к. алгоритм поиска не умеет работать с троичной логикой. А следовательно, такие записи должно быть невозможно вставить в таблицу (при наличии многомерного индекса, необязательно логического, кстати)


Ожидается, что логический многомерный индекс может в некоторых случаях работать не слишком эффективно. Строго говоря, любой индекс может работать неэффективно, если слишком большое количество данных попадает в область поиска. Но для логического многомерного индекса это усугубляется описанной выше зависимостью от порядка полей, когда ради небольшого результата придётся прочитать весь индекс. Насколько это является проблемой на практике, может показать только эксперимент.

Численный эксперимент


Построение индекса:

  • индекс будет 128-разрядным, т.е. построен по 128 логическим полям
  • и будет содержать 2**30 элементов
  • значением элемента индекса будет число от 0 до 2**30
  • ключом элемента индекса будет то же число, сдвинутое на 48 разрядов влево, т.е. логические поля с 48 по 78 будут заполнены разрядами числа в том же порядке
  • в результате получим 30 значимых логических полей в середине ключа, остальные разряды будут заполнены 0
  • Каждое из логических полей имеет равную статистику true/false
  • Все они статистически независимы


Поиск:

  • Каждому эксперименту соответствует выбор нескольких подряд идущих логических полей и задание для них поисковых значений. Не потому, что алгоритм умеет искать только полосами, а из-за того, что так можно нагляднее представить результаты эксперимента, имеем всего две размерности — ширина полосы и её положение
  • Всего 24 серии экспериментов. В каждой серии будем искать такие значения, где полоса логических полей соответствующей ширины N (от 1 до 24 разрядов) принимает значение true.
  • В каждой серии будет подсерия экспериментов, в которой полоса логических полей выбранной ширины располагается с различными сдвигами S от начала полосы в 30 значимых логических полей. Всего (30-N) экспериментов в подсерии.
  • В каждом эксперименте делается поиск всех элементов индекса, удовлетворяющих условию, т.е. поля с номерами в интервале [48 + S, 48 + S + N -1] будем искать в интервале [1,1], остальные — в интервале [0,1]
  • Поиск делается с холодного старта
  • Результатом является число прочитанных дисковых страниц, с учетом кэширования (кэш на 4096 страниц)
  • Контроль правильности работы делается двумя путями — число найденных элементов должно быть равно 2**(30-N) и в найденных значениях можно проверить соответствующие разряды


Итак,

Фиг. 4 Результаты, число прочитанных страниц в разных сериях

По Y — отложены количества прочитанных страниц.

По X — сдвиг полос от самого младшего (48) разряда к старшему. Полосы разной ширины подписаны и отмечены разными цветами.

Фиг.5 Те же данные что и Фиг.4, другое представление

По X — сдвиг полосы

По Y — ширина полосы

Что следует отметить:

  • хотя на картинках это прямо не видно, индекс работает правильно, это видно и по числу найденных элементов и по содержанию самих элементов
  • все полосы шириной не больше 10 со сдвигом 0 требуют сплошного чтения индекса
  • полосы шириной от 1 до 18 с ростом сдвига выходят на асимптоту 2**(-N) от размера всего индекса, что логично
  • для более широких полос асимптота — высота дерева, меньше неё чтений быть не может
  • на листовой странице индекса помещается чуть больше 1000 элементов, это видно по полосе шириной 10, которая при сдвиге 0 уже не требует чтения всего индекса, некоторые страницы удаётся пропускать
  • низкоуровневая фильтрация работает на удивление хорошо. Рассмотрим полосу шириной 10. Идеальный для поиска вариант — со сдвигом 20 (всего 30 значимых полей), когда в префиксе вообще нет неопределенных полей, данные можно найти единственным траверзом. В этой ситуации при поиске читается примерно 1/1000 индекса — 779 страниц.

    Промежуточный случай — сдвиг 10, у нас префикс и суффикс в 10 неизвестных полей. Число страниц — 2484, всего втрое хуже, чем в идеальном случае.

    И даже в худшем случае со сдвигом в 0 (префикс в 20 неизвестных полей) удаётся пропускать какие-то страницы.


В целом можно признать алгоритм многомерной индексации работоспособным даже в таком доведенном до абсурда случае.

А ведь рассматривается самый неудачный с точки зрения логического индекса вариант — равновероятные состояния по всем независимым логическим полям.

Эксперимент на реальных данных


Таблица Trades, всего 278 479 918 строк, данные одного из тестовых контуров.

Результаты выполнения некоторых запросов в таблице ниже:









NЗапросЧисло строк в результатеПрочитано страниц
1IsProcessed==0 && NullStatus==06 2739
2IsProcessed==0 && NullStatus==0 && IsCoverage==06 2739
3IsCoverage==1 && QF_ICEBERG==11 388 128386
4PutStatus==1 && PayStatus == 061 788 37616 486
5IsProcessed==1 && NullStatus==0 &&

QF_CURR_PFI==0 && QF_TERMINATION==0
278 473 64574 285
6IsProcessed==1 && PutStatus==0 &&

IsCoverage==1
1 650 240447
7QF_UNK3==0 && QF_UNK4==023 39219


На чтение/обработку одной страницы в среднем уходит 0. 8 мсек.

Нет необходимости описывать смысл конкретных запросов, они здесь просто для демонстрации работоспособности. Которая, кстати, подтверждена.

Но прежде чем данная техника сможет принести практическую пользу, предстоит еще очень много сделать. Так что, продолжение следует.

Как добавить столбец логического типа данных в существующую таблицу в SQL?

В SQL Server логический тип данных может быть создан путем сохранения типа данных BIT. Хотя это числовой тип данных, он может принимать только значения 0, 1 или NULL. Следовательно, мы легко можем присвоить значения FALSE 0 и значения TRUE 1. Это обеспечит логическую природу типа данных.

Что касается хранилища, если в таблице присутствует менее 9 столбцов битовых данных, они сохраняются как 1 байт. И за 9до 16-битных столбцов, их потребление составляет 2 байта и так далее. В этой статье мы расскажем, как добавить логический тип данных, т. е. BIT, в существующую таблицу в SQL SERVER.

Предположим, что имеется база данных «GEEKSFORGEEKS» и доступна таблица «Авторы» со следующими данными.

Запрос:

 ИСПОЛЬЗУЙТЕ GEEKSFORGEEKS
ВЫБЕРИТЕ * ОТ авторов; 

Вывод:

Добавим в таблицу «Авторы» тип данных BIT. Тип данных Bit полезен для представления логической природы True (1) или False (0), и они являются единственными допустимыми значениями для типа данных BIT.

 -- Добавить столбец с именем "isActiveAuthor"
с типом данных BIT для таблицы "Авторы"
ALTER TABLE Authors ADD isActiveAuthor BIT; 

Поскольку в таблице уже доступно несколько строк, мы можем добавить новый столбец «isActiveAuthor» только как шаблон NULL. После этого мы можем обновить данные. После добавления столбца 

Запрос:

 SELECT * FROM Authors; 

Вывод:

Таким образом, когда столбец типа данных BIT добавляется в существующую таблицу, его значение будет заполнено значениями «NULL».

Теперь давайте попробуем обновить столбец с условием, что если «NumberOfPosts» > 5, установите для «isActiveAuthor» значение 1 или 0.  

 -- Предположим, что если «NumberOfPosts»
   больше 5, автор достаточно активен, чтобы писать статьи
-- Следовательно, для этого условия установите "isActiveAuthor"
   столбец со значением 1
ОБНОВЛЕНИЕ Авторы SET isActiveAuthor = 1 WHERE NumberOfPosts > 5;
-- С другой стороны, если "NumberOfPosts"
   меньше и равно 5,
-- автор неактивен в последние дни
   и, следовательно, установите для столбца «isActiveAuthor» значение 0
ОБНОВЛЕНИЕ Авторы SET isActiveAuthor = 0 WHERE NumberOfPosts <= 5;
ВЫБЕРИТЕ * ОТ авторов; 

Вывод:

Поскольку столбец BIT поддерживает только 0 или 1 в качестве значений, мы заполнили его, как указано выше.

Давайте попробуем обновить значение, отличное от 0 или 1 

 -- Попытка обновить "isActiveAuthor"
   со значением 2, хотя ошибок нет
   производится, выход отличается
ОБНОВЛЕНИЕ Авторы SET isActiveAuthor =
2 ГДЕ Количество сообщений = 5;
ВЫБЕРИТЕ * ОТ авторов; 

Вывод:

Причина обновленного значения 1 в 3-й строке:

Хотя для получения значения 2 дано обновление, из-за типа данных «BIT» для столбца «isActiveAuthor» его значение преобразуется только в 1, поскольку тип данных «BIT» поддерживает только 0 или 1. т. е. значения, отличные от 0, преобразуются в 1 и обновляются в таблице.

Мы можем проверить то же самое здесь на разных примерах

 DECLARE @isValid BIT
-- Первоначально он будет иметь значение "NULL"
ВЫБЕРИТЕ @isValid AS BitType
 
--Присвоение любого ненулевого значения преобразует его в 1
-- т.е. кроме 0, если есть
   предоставляется значение, оно преобразуется в 1
НАБОР @isValid=9ВЫБЕРИТЕ @isValid AS BitType
 
--Присвоение любого ненулевого значения преобразует его в 1
НАБОР @isValid=-100
 
SELECT @isValid AS BitType 

Вывод:

Это доказывает, что тип данных «BIT» принимает только «логическое» значение, то есть только 0 или 1. Если задано ненулевое значение, оно преобразуется только в 1.

Преимущества:

  • Всегда, если ожидаемые значения либо 0, либо 1 плюс NULL, рекомендуется сохранить столбец как тип данных «BIT», поскольку код становится логическим
  • Что касается хранения, то оно экономично, так как занимает мало места по сравнению с другими типами данных.

Учитывая преимущества, тип данных BIT является правильным подходом для хранения логических данных

Существует ли логический тип данных в Microsoft SQL Server, как в MySQL

1 ответ на этот вопрос.

0 голосов

Связанные вопросы в базе данных

Неа. Я не думаю, что есть один
Но... ПОДРОБНЕЕ

ответил

10 октября 2018 г.

в базе данных

к
Неха

• 6 300 баллов

579Просмотры

  • оракул
  • sql
  • база данных

Из-за оптимизаций, скорее всего. Есть ... ПОДРОБНЕЕ

ответил

30 марта 2022 г.

в базе данных

к
гаурав

• 22,980 баллов

290 просмотров

  • excelrow-номерлимиты

В SQL Server 2000, как вы... ПОДРОБНЕЕ

25 августа 2022 г.

в базе данных

к
Китузз

• 38 010 баллов

265 просмотров

  • хранимые процедуры
  • SQL-сервер-2000
  • sql-дроп

Я хочу использовать скрипт для. .. ПОДРОБНЕЕ

29 августа 2022 г.

в базе данных

к
Китузз

• 38 010 баллов

138 просмотров

  • sql
  • sql-сервер
  • SQL-сервер-2008

Как должно быть да/нет или логическое поле... ПОДРОБНЕЕ

5 сентября 2022 г.

в базе данных

к
Китузз

• 38 010 баллов

499 просмотров

  • SQL-сервер
  • логическое значение
  • sqldatatypes

используйте типы данных с плавающей запятой или вещественные только в том случае, если точность обеспечивается десятичной дробью (до ... ПОДРОБНЕЕ

ответил

11 сентября 2022 г.

в базе данных

к
нариккадан

• 63 040 баллов

747 просмотров

  • sql
  • sql-сервер
  • типы

Я пытаюсь напечатать false, используя ... ПОДРОБНЕЕ

17 сентября 2018 г.

в Питоне

к
ана1504.к

• 7 910 баллов

211 просмотров

  • питон
  • питон2
  • логическое значение

Я думаю, что это решение требует реализации CROSS JOIN. ... ПОДРОБНЕЕ

ответил

26 октября 2018 г.

в Power BI

к
Упасана

• 8 620 баллов

431 просмотр

  • мощность-би
  • sql
  • sql-сервер
  • дакс

Решение
Выберите Пуск > Программы > Microsoft SQL Server > Enterprise Manager.
Щелкните правой кнопкой мыши SQL ... ПОДРОБНЕЕ

ответил
12 сентября 2022 г.
в базе данных
к
нариккадан
• 63 040 баллов

566 просмотров

  • sql
  • sql-сервер
  • SQL-сервер-2008

Комбинации LIKE & IN нет... ПОДРОБНЕЕ

ответил
18 сентября 2022 г.
в базе данных
к
нариккадан
• 63 040 баллов

382 просмотра

  • SQL-сервер
  • sql
  • оракул
  • тскл
  • PLSQL
  • Получить значения объектов json и сохранить их в виде массивов 16 ноября 2022 г.
  • Могут ли массивы PHP содержать элементы разных типов? 16 ноября 2022 г.
  • ОШИБКА 1064 (42000): ошибка в синтаксисе SQL; 19 сентября 2022 г.
  • Удалить все записи 19 сентября 2022 г.
  • Как создать уникальное ограничение для столбца (SQL Server 2008 R2)? 19 сентября 2022 г.
  • Все категории
  • ЧатGPT
    (11)
  • Апач Кафка
    (84)
  • Апач Спарк
    (596)
  • Лазурный
    (145)
  • Большие данные Hadoop
    (1907)
  • Блокчейн
    (1673)
  • С#
    (141)
  • С++
    (271)
  • Консультирование по вопросам карьеры
    (1060)
  • Облачные вычисления
    (3469)
  • Кибербезопасность и этичный взлом
    (162)
  • Аналитика данных
    (1266)
  • База данных
    (855)
  • Наука о данных
    (76)
  • DevOps и Agile
    (3608)
  • Цифровой маркетинг
    (111)
  • События и актуальные темы
    (28)
  • IoT (Интернет вещей)
    (387)
  • Джава
    (1247)
  • Котлин
    (8)
  • Администрирование Linux
    (389)
  • Машинное обучение
    (337)
  • Микростратегия
    (6)
  • PMP
    (423)
  • Power BI
    (516)
  • питон
    (3193)
  • РПА
    (650)
  • SalesForce
    (92)
  • Селен
    (1569)
  • Тестирование программного обеспечения
    (56)
  • Таблица
    (608)
  • Таленд
    (73)
  • ТипСкрипт
    (124)
  • Веб-разработка
    (3002)
  • Спросите нас о чем угодно!
    (66)
  • Другие
    (2231)
  • Мобильная разработка
    (395)
  • Пользовательский интерфейс UX-дизайн
    (24)

Подпишитесь на нашу рассылку новостей и получайте персональные рекомендации.