设置变量
mysql> set @var=10;
Query OK, 0 rows affected (0.00 sec)
mysql> select @var;
+------+
| @var |
+------+
| 10 |
+------+
1 row in set (0.00 sec)
MySQL常量
MySQL有四个常量: true
false
TRUE
FALSE
分别对应着 1 0 1 0
位模式字面量
MySQL 中的位模式字面量一般使用 b'val'
或0bval
语法,
val
是只包含 0 和 1 的二进制值,字符 b
之前有无 0 都无关紧要,
但要注意的是 0b
是区分大小写的,0b
不能写为 0B
,
但b'val'
形式的b
不限大小写。b001
和 B001
是一个意思。
例如:
mysql> SELECT b'1000001', CHARSET(b'1000001');
+------------+---------------------+
| b'1000001' | CHARSET(b'1000001') |
+------------+---------------------+
| A | binary |
+------------+---------------------+
mysql> SELECT 0b1100001, CHARSET(0b1100001);
+-----------+--------------------+
| 0b1100001 | CHARSET(0b1100001) |
+-----------+--------------------+
| a | binary |
+-----------+--------------------+
位类型字面量可以有一个可选的字符集介绍器和 COLLATE 子句,用于指定为使用特定字符集和排序规则的字符串
[_charset_name] b'val' [COLLATE collation_name]
例如:
mysql> SELECT _latin1 b'1000001';
+--------------------+
| _latin1 b'1000001' |
+--------------------+
| A |
+--------------------+
1 row in set (0.01 sec)
mysql> SELECT _utf8 0b1000001 COLLATE utf8_danish_ci;
+----------------------------------------+
| _utf8 0b1000001 COLLATE utf8_danish_ci |
+----------------------------------------+
| A |
+----------------------------------------+
1 row in set (0.02 sec)
默认情况下,位类型的字面量是一个二进制字符串, 会以ASCII字符显示
如果想转换成数字:
可以在把这个位类型数据进行+ 0
操作或者使用 CAST (... AS UNSIGNED)
转换器。
# =================================================
# mysql> SET @v1 = b'1100001';
# mysql> SET @v2 = b'1100001'+0;
# mysql> SET @v3 = CAST(b'1100001' AS UNSIGNED);
# mysql> SET @v4 = b'';
# mysql> SELECT @v1, @v2, @v3, @v4+0;
# +------+------+------+------+
# | @v1 | @v2 | @v3 | @v4 |
# +------+------+------+------+
# | a | 97 | 97 | 0 |
# +------+------+------+------+
# =======================================================
在查询时,结果集中的位值将作为二进制值返回,可读性就会差很多,
这时候我们可以将它们转换为十进制或者十六进制,
可以使用转换函数 bin() 或 hex()
两个函数来完成这种转换。
转换的时候会忽略高位中的 0
# =============================================
# mysql> SELECT b+0, BIN(b), OCT(b), HEX(b) FROM t;
# +------+----------+--------+--------+
# | b+0 | BIN(b) | OCT(b) | HEX(b) |
# +------+----------+--------+--------+
# | 255 | 11111111 | 377 | FF |
# | 10 | 1010 | 12 | A |
# | 5 | 101 | 5 | 5 |
# +------+----------+--------+--------+
# =============================================
对于位类型,位操作被视为应当在数字上下文中进行,但在 MySQL 8.0 及更高的版本中,可以直接使用位操作数字或二进制字符串参数
在这种情况下,就至少要位其中一个参数使用 _binary
介绍器,将位类型的数据指定为二进制字符串上下文
# ===============================================
mysql> SET @v1 = b'000010101' | b'000101010';
mysql> SET @v2 = _binary b'000010101' | _binary b'000101010';
mysql> select @v1, @v2;
+------+------+
| @v1 | @v2 |
+------+------+
| 63 | ? |
+------+------+
# ===============================================
在上面这个范例中,没有_binary
的结果是 BIGINT 值,
而_binary
的结果是二进制字符串。