发现MySQL列的排序规则

Tri*_*daz 39 mysql collation

我之前创建了一个MySQL表,现在我想找出一些字段正在使用的排序规则.我可以使用哪些SQL或MySQL命令来发现它?

0x4*_*672 58

您可以使用SHOW FULL COLUMNS FROM tablename哪个返回列Collat​​ion,例如对于'name'列上具有特殊排序规则的表'accounts'

mysql> SHOW FULL COLUMNS FROM accounts;
+----------+--------------+-------------------+------+-----+---------+----------+
| Field    | Type         | Collation         | Null | Key | Default | Extra    |
+----------+--------------+-------------------+------+-----+---------+----------|
| id       | int(11)      | NULL              | NO   | PRI | NULL    | auto_inc |
| name     | varchar(255) | utf8_bin          | YES  |     | NULL    |          |
| email    | varchar(255) | latin1_swedish_ci | YES  |     | NULL    |          |
...
Run Code Online (Sandbox Code Playgroud)

或者您可以使用SHOW CREATE TABLE tablename哪个会产生类似的声明

mysql> SHOW CREATE TABLE accounts;
CREATE TABLE `accounts` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL,
`email` varchar(255) DEFAULT NULL,
...
Run Code Online (Sandbox Code Playgroud)

  • 仅供参考,如果与表默认值不同,SHOW CREATE TABLE 仅显示列 SET 和 COLLATE。此外,如果与数据库默认值相同,则不会显示表默认值。 (2认同)

Hol*_*ger 12

如果您想要对该特定列进行排序(可能与子查询一起使用)...

SELECT COLLATION_NAME
FROM information_schema.columns
WHERE TABLE_SCHEMA = 'tableschemaname'
AND TABLE_NAME = 'tablename'
AND COLUMN_NAME = 'fieldname';
Run Code Online (Sandbox Code Playgroud)