Pregunta ¿Cómo veo qué conjunto de caracteres es una base de datos / tabla / columna MySQL?


¿Cuál es el juego de caracteres (predeterminado) para:

  • Base de datos MySQL

  • Tabla MySQL

  • Columna MySQL


514
2018-06-26 15:22


origen


Respuestas:


Así es como lo haría -

Para los esquemas:

SELECT default_character_set_name FROM information_schema.SCHEMATA 
WHERE schema_name = "schemaname";

Para tablas:

SELECT CCSA.character_set_name FROM information_schema.`TABLES` T,
       information_schema.`COLLATION_CHARACTER_SET_APPLICABILITY` CCSA
WHERE CCSA.collation_name = T.table_collation
  AND T.table_schema = "schemaname"
  AND T.table_name = "tablename";

Para Columnas:

SELECT character_set_name FROM information_schema.`COLUMNS` 
WHERE table_schema = "schemaname"
  AND table_name = "tablename"
  AND column_name = "columnname";

587
2018-06-26 16:07



por columnas:

SHOW FULL COLUMNS FROM table_name;

401
2018-01-26 14:16



por bases de:

USE your_database_name;
show variables like "character_set_database";
-- or:
-- show variables like "collation_database";

Cf. esta página. Y mira el manual de MySQL


200
2018-06-26 15:29



Para todas las bases de datos tienes en el servidor:

mysql> SELECT SCHEMA_NAME 'database', default_character_set_name 'charset', DEFAULT_COLLATION_NAME 'collation' FROM information_schema.SCHEMATA;

Salida:

+----------------------------+---------+--------------------+
| database                   | charset | collation          |
+----------------------------+---------+--------------------+
| information_schema         | utf8    | utf8_general_ci    |
| my_database                | latin1  | latin1_swedish_ci  |
...
+----------------------------+---------+--------------------+

Para Base de datos individual:

mysql> USE my_database;
mysql> show variables like "character_set_database";

Salida:

    +----------------------------+---------+
    | Variable_name              |  Value  |
    +----------------------------+---------+
    | character_set_database     |  latin1 | 
    +----------------------------+---------+

Obteniendo la colación para tablas:

mysql> USE my_database;
mysql> SHOW TABLE STATUS WHERE NAME LIKE 'my_tablename';

O bien, generará el SQL completo para crear la tabla:

mysql> show create table my_tablename 


Obtener la recopilación de columnas:

mysql> SHOW FULL COLUMNS FROM my_tablename;

salida:

+---------+---------+--------------------+ ....
| field   | type    | collation          |
+---------+---------+--------------------+ ....
| id      | utf8    | (NULL)             |
| key     | utf8    | latin1_swedish_ci  |
| value   | utf8    | latin1_swedish_ci  |
+---------+---------+--------------------+ ....

83
2017-08-17 12:32



por mesas:

SHOW TABLE STATUS listará todas las tablas.

Filtrar usando:

SHOW TABLE STATUS where name like 'table_123';

57
2018-06-26 15:28



por bases de:

Solo usa estos comandos:

USE db_name;
SELECT @@character_set_database;
-- or:
-- SELECT @@collation_database;

43
2018-05-21 09:25



SELECCIONE TABLE_SCHEMA,
       NOMBRE DE LA TABLA,
       CCSA.CHARACTER_SET_NAME AS DEFAULT_CHAR_SET,
       COLUMN_NAME,
       COLUMN_TYPE,
       C.CHARACTER_SET_NAME
  FROM information_schema.TABLES AS T
  ÚNASE A Information_schema.COLUMNS AS C USING (TABLE_SCHEMA, TABLE_NAME)
  ÚNASE a information_schema.COLLATION_CHARACTER_SET_APPLICABILITY AS CCSA
       ENCENDIDO (T.TABLE_COLLATION = CCSA.COLLATION_NAME)
 DONDE TABLE_SCHEMA = SCHEMA ()
   Y C.DATA_TYPE IN ('enum', 'varchar', 'char', 'text', 'mediumtext', 'longtext')
 ORDER BY TABLE_SCHEMA,
          NOMBRE DE LA TABLA,
          COLUMN_NAME
;

28
2018-01-26 14:56



Yo siempre miro SHOW CREATE TABLE mydatabase.mytable.

Para la base de datos, parece que necesita mirar SELECT DEFAULT_CHARACTER_SET_NAME FROM information_schema.SCHEMATA.


20
2018-06-26 15:26



por mesas y columnas:

show create table your_table_name

20
2018-06-26 15:28