- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不想挑剔,但为什么在您将表列定义为 boolean 值的那一刻,在您尝试取回表结构的那一刻,它却作为 tinyint(1) 返回?
所以对于创建的表
CREATE TABLE IF NOT EXISTS `test` (
`aField` BOOLEAN DEFAULT true
);
当我尝试获取它的结构时
SHOW COLUMNS FROM test
我得到了
+--------+------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+------------+------+-----+---------+-------+
| aField | tinyint(1) | YES | | 1 | |
+--------+------------+------+-----+---------+-------+
对于 boolean 值存储为 tinyint(1) 的事实,我没有(大)问题,但我有一个问题,即当您看到 tinyint(1) 时,您不知道如果它最初是作为 boolean 值或作为存储小数字范围的小整数创建的。我看到 MySQL 文档 ( https://dev.mysql.com/doc/refman/5.7/en/numeric-type-overview.html ) 说
BOOL, BOOLEAN These types are synonyms for TINYINT(1)
但我不同意上述问题。
是否有任何其他我可以运行的查询会返回字段的原始( boolean )类型?
最佳答案
不,您无法区分创建为 BOOLEAN 的列和创建为 TINYINT(1) 的列。
BOOLEAN 类型没有存储在任何地方。它只是像一个别名,在存储到数据库之前被转换为 TINYINT(1)。您不会在列的元数据中找到对 BOOLEAN 的任何提及。
这就像您存储来自表达式 ABS(?)
的整数值。您不知道传递给 ABS() 的原始值是正数还是负数,因为只存储了 ABS() 表达式的结果。
顺便说一下,TINYINT(1) 并不意味着它只允许很小的数字范围。很自然地认为 (1) 是一个大小限制,就像它对 CHAR 或 DECIMAL 一样。但对于 MySQL 中的整数类型,它对数据类型的大小或它接受的值的范围没有影响。 TINYINT 始终是一个 8 位整数,并且接受从 -128 到 127 的值,或者对于 TINYINT UNSIGNED,它总是接受从 0 到 255 的值。
另请参阅我对 https://stackoverflow.com/a/3135854/20860 的回答
关于MySQL:从 Boolean 到 Tinyint(1) 再返回,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58251926/
我正在尝试从文本文件构建 boolean 值[][]。我正在读取每个字符,存储在 ArrayList 中(1 为真,0 为假)。我试过 ArrayList,但出现编译错误,意外元素。因此,我构建了一个
我想知道编程语言中的运算符优先级是否取决于实现,还是所有语言都遵循固定的规则。并且,如果可能的话,您可以先排序以下具有最高优先级的运算符吗:AND,OR,NOT,XOR。 最佳答案 我在Google上
这是同样的事情,对吗?还是有细微的差别?我只是想确保我没有误解任何事情。 最佳答案 通过简单地将 AND 替换为 OR 以及将 OR 替换为 AND 即可生成 boolean 对偶。补码本身不受影响,
我想这对于大多数优秀的程序员来说是微不足道的,但我已经习惯使用 true 进行编程。和 false 2、当我遇到0和1的时候,我永远记不住哪一个是真的,哪一个是假的。 有什么建议? 1好:I mean
我正在尝试将此 Java 示例转换为 Kotlin: Gson gson = new GsonBuilder() .registerTypeAdapter(Boolean.class,
下面的代码打印 true。 public static void main(String[] args) { Boolean test = false; test =
我在处理应该导致在 iReport 中显示或隐藏 strip 的表达式时遇到困难。 这些是我拥有的变量: Integer mainGroupInt = Integer.valueOf(5); Inte
以下编码错误可能是因为 Boolean equals(Object) 方法不需要 boolean/Boolean 参数: private void foo() { Boolean isSome
我想简化一个 boolean 表达式。 表达式是这样的 X1 xor (X2 || X3 && X4 || x5) 如何使用 boolean 代数规则简化此表达式。 而且我想将上面的 boolean
我正在使用一些工具,它可以确定特定事务是否成功的唯一方法是它是否通过了各种检查。但是,它的方式有限制,一次只能做一次检查,而且必须是顺序的。一切都必须从左到右计算。 例如, A || C && D 它
在大多数编程语言中,1和 0可以用来代替 True和 False .然而,根据我的经验,整数似乎总是更容易使用。 以下是我的意思的一些示例: if x is True: x = False else:
我有一个 boolean 方程,想简化它。帮忙解决一下。 bool needLoad = isA || (!isA && !isB); 之后我使用 if (needLoad){ if (
我认为这始终是正确的 x || (x && y) 相当于 x 如果是这样,那条法律叫什么?我什至不知道如何通过 Google 搜索该信息。 最佳答案 它被称为 Redundancy Law . A +
是否有任何现有的方法或功能模块可以有效地翻转 boolean 值? 如果我必须定义自己的实用方法,我想出了一个简单的实现,但我想知道这是否是最有效的方法: IF iv_bool = abap_true
我有这个表达式:X'YZ'+X'YZ+XY'Z'+XYZ'+XYZ('表示不是)我知道答案是 Y+XZ' 但我陷入了最后一部分。有人可以帮我吗? 这是我到目前为止得到的: X'YZ' + X'YZ +
openCL 支持 boolean 变量吗?我目前正在使用 JOCL (java) 编写我的 openCL 调用代码,但我没有看到任何有关 boolean 值的信息。 最佳答案 tl;dr:是的,但您
我认为这是对的 x || (x && y) 相当于 x 如果是这样,那条法律叫什么?我什至不确定我会如何使用 Google。 最佳答案 它叫做 Redundancy Law . A + A·B = A
我有一些功能,例如 (A and ( B or c)) or (D and E and (F or H or R or P ))) 我想将该函数转换为仅包含 and 操作的函数(当然如果可能的话)我发
我参加了编程面试,由 3 名面试官组成,每人 45 分钟。虽然前两位面试官给了我 2-3 个简短的编码问题(即反向链表、使用 rand(5) 实现 rand(7) 等),但第三位面试官使用了整个时间段
如果我只想检查某事是否不可能(即,我不会使用类似 if(possible) 的东西),我应该将 boolean 值命名为 notPossible并使用 if(notPossible)或者我应该命名它p
我是一名优秀的程序员,十分优秀!