Хранить логическое значение в SQLite - PullRequest
243 голосов
/ 09 мая 2009

Какой тип значения BOOL в SQLite? Я хочу сохранить в моей таблице значения TRUE / FALSE.

Я мог бы создать столбец INTEGER и сохранить в нем значения 0 или 1, но это не лучший способ для реализации типа BOOL.

Есть ли способ?

Спасибо.

Ответы [ 9 ]

327 голосов
/ 09 мая 2009

Нет собственного логического типа данных для SQLite. В соответствии с Datatypes doc :

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

82 голосов
/ 31 января 2012

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

Вы можете преобразовать логическое значение в int следующим образом:

int flag = (boolValue)? 1 : 0;

Вы можете преобразовать int обратно в логическое значение следующим образом:

 // Select COLUMN_NAME  values from db. 
 // This will be integer value, you can convert this int value back to Boolean as follows
Boolean flag2 = (intValue == 1)? true : false;

Если вы хотите изучить sqlite, вот учебник .
Я дал один ответ здесь . Это работает для них.

73 голосов
/ 05 марта 2014

В SQLite лучшее, что вы можете сделать, это использовать целые числа 0 и 1 для представления значений false и true. Вы можете объявить тип столбца следующим образом:

CREATE TABLE foo(mycolumn BOOLEAN NOT NULL CHECK (mycolumn IN (0,1)));

Опустите NOT NULL, если вы хотите разрешить NULL в дополнение к 0 и 1.

Использование имени типа BOOLEAN здесь для удобства чтения, для SQLite это просто тип с NUMERIC-сходством .

Обратите внимание, что ограничения CHECK поддерживаются с SQLite 3.3.0 (2006).

Вот несколько примеров INSERT, которые будут работать: (обратите внимание, как строки и числа с плавающей запятой анализируются как целые числа)

sqlite> INSERT INTO foo VALUES(0);
sqlite> INSERT INTO foo VALUES(1);
sqlite> INSERT INTO foo VALUES(0.0);
sqlite> INSERT INTO foo VALUES(1.0);
sqlite> INSERT INTO foo VALUES("0.0");
sqlite> INSERT INTO foo VALUES("1.0");
sqlite> select mycolumn, typeof(mycolumn) from foo;
0|integer
1|integer
0|integer
1|integer
0|integer
1|integer

и некоторые, которые потерпят неудачу:

sqlite> INSERT INTO foo VALUES("-1");
Error: constraint failed
sqlite> INSERT INTO foo VALUES(0.24);
Error: constraint failed
sqlite> INSERT INTO foo VALUES(100);
Error: constraint failed
sqlite> INSERT INTO foo VALUES(NULL);
Error: foo.mycolumn may not be NULL
sqlite> INSERT INTO foo VALUES("true");
Error: constraint failed
sqlite> INSERT INTO foo VALUES("false");
Error: constraint failed
7 голосов
/ 27 февраля 2012

с использованием типа данных Integer со значениями 0 и 1 - самый быстрый.

5 голосов
/ 18 февраля 2016

Но, если вы хотите сохранить кучу из них, вы можете сдвинуть их побитно и сохранить их как один int, немного похоже на разрешения / режимы для файлов Unix.

Например, для режима 755 каждая цифра относится к разному классу пользователей: владелец, группа, общедоступный. Внутри каждой цифры 4 читается, 2 - запись, 1 - выполняется, поэтому 7 - все они, как двоичный файл 111. 5 читается и выполняется, так 101. Создайте свою собственную схему кодирования.

Я просто пишу что-то для хранения данных телепрограмм из Schedules Direct, и у меня есть двоичные поля или поля да / нет: стерео, hdtv, new, ei, с субтитрами, dolby, sap на испанском, премьера сезона. Таким образом, 7 бит или целое число с максимумом 127. Один символ на самом деле.

Пример C из того, над чем я сейчас работаю. has () - это функция, которая возвращает 1, если вторая строка находится в первой. inp является входной строкой для этой функции. misc - это неподписанный символ, инициализированный 0. 0. 1007 *

if (has(inp,"sap='Spanish'") > 0)
  misc += 1;
if (has(inp,"stereo='true'") > 0)
  misc +=2;
if (has(inp,"ei='true'") > 0)
  misc +=4;
if (has(inp,"closeCaptioned='true'") > 0)
  misc += 8;
if (has(inp,"dolby=") > 0)
  misc += 16;
if (has(inp,"new='true'") > 0)
  misc += 32;
if (has(inp,"premier_finale='") > 0)
  misc += 64;
if (has(inp,"hdtv='true'") > 0)
  misc += 128;

Таким образом, я храню 7 логических значений в одном целом числе с местом для большего количества.

4 голосов
/ 08 октября 2015

В дополнение к ответу Эриквы. Ограничения CHECK могут включать псевдо-логический столбец, применяя тип данных TEXT и позволяя использовать только значения TRUE или FALSE для конкретного случая, например,

CREATE TABLE IF NOT EXISTS "boolean_test"
(
    "id" INTEGER PRIMARY KEY AUTOINCREMENT
,   "boolean" TEXT NOT NULL 
        CHECK( typeof("boolean") = "text" AND
               "boolean" IN ("TRUE","FALSE")
        )
);

INSERT INTO "boolean_test" ("boolean") VALUES ("TRUE");
INSERT INTO "boolean_test" ("boolean") VALUES ("FALSE");
INSERT INTO "boolean_test" ("boolean") VALUES ("TEST");

Error: CHECK constraint failed: boolean_test

INSERT INTO "boolean_test" ("boolean") VALUES ("true");

Error: CHECK constraint failed: boolean_test

INSERT INTO "boolean_test" ("boolean") VALUES ("false");

Error: CHECK constraint failed: boolean_test

INSERT INTO "boolean_test" ("boolean") VALUES (1);

Error: CHECK constraint failed: boolean_test

select * from boolean_test;

id  boolean
1   TRUE
2   FALSE
1 голос
/ 18 августа 2014

Вы можете упростить приведенные выше уравнения, используя следующее:

boolean flag = sqlInt != 0;

Если представление int (sqlInt) логического значения равно 0 (false), логическое значение (flag) будет false, в противном случае оно будет истинным.

С кратким кодом работать всегда приятнее:)

0 голосов
/ 07 января 2017

ОБНОВЛЕНИЕ таблицы SET Boolcolumn = '1' ГДЕ ......

0 голосов
/ 07 января 2014

Еще один способ сделать это - столбец TEXT. А затем преобразуйте логическое значение между Boolean и String до / после сохранения / чтения значения из базы данных.

Ex. У вас есть "boolValue = true; "

В строку:

//convert to the string "TRUE"
string StringValue = boolValue.ToString;  

И вернемся к логическому:

//convert the string back to boolean
bool Boolvalue = Convert.ToBoolean(StringValue);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...