Bootstrap

MySQL学习之变量和常量

设置变量

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不限大小写。b001B001 是一个意思。

例如:

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 的结果是二进制字符串。

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;