Yanıtlar:
İşte böyle yapardım -
Şemalar (veya Veritabanları - eşanlamlıdır) için:
SELECT default_character_set_name FROM information_schema.SCHEMATA
WHERE schema_name = "schemaname";
Tablolar için:
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";
Sütunlar için:
SELECT character_set_name FROM information_schema.`COLUMNS`
WHERE table_schema = "schemaname"
AND table_name = "tablename"
AND column_name = "columnname";
schemaname
sadece veritabanı adı olabilir.
İçin sütunlar :
SHOW FULL COLUMNS FROM table_name;
latin1_swedish_ci
karakter kümesi dışında başka bir şey olamaz latin1
. Harmanlama ise utf8mb4_general_ci
karakter kümesi dışında başka bir şey olamaz utf8mb4
.
İçin veritabanları :
USE your_database_name;
show variables like "character_set_database";
-- or:
-- show variables like "collation_database";
Krş bu sayfa . Ve MySQL kılavuzuna göz atın
Sunucuda bulunan tüm veritabanları için:
mysql> SELECT SCHEMA_NAME 'database', default_character_set_name 'charset', DEFAULT_COLLATION_NAME 'collation' FROM information_schema.SCHEMATA;
Çıktı:
+----------------------------+---------+--------------------+
| database | charset | collation |
+----------------------------+---------+--------------------+
| information_schema | utf8 | utf8_general_ci |
| my_database | latin1 | latin1_swedish_ci |
...
+----------------------------+---------+--------------------+
Bir İçin Tek Veritabanı :
mysql> USE my_database;
mysql> show variables like "character_set_database";
Çıktı:
+----------------------------+---------+
| Variable_name | Value |
+----------------------------+---------+
| character_set_database | latin1 |
+----------------------------+---------+
Tablolar için harmanlama alma :
mysql> USE my_database;
mysql> SHOW TABLE STATUS WHERE NAME LIKE 'my_tablename';
VEYA - tablo oluşturmak için tam SQL çıktısı verir:
mysql> show create table my_tablename
Sütunların harmanlanmasını alma :
mysql> SHOW FULL COLUMNS FROM my_tablename;
çıktı:
+---------+--------------+--------------------+ ....
| field | type | collation |
+---------+--------------+--------------------+ ....
| id | int(10) | (NULL) |
| key | varchar(255) | latin1_swedish_ci |
| value | varchar(255) | latin1_swedish_ci |
+---------+--------------+--------------------+ ....
type
? Ben MySQL 5.7.9 var ve type
göstermek data type
sütunun değil character set
. Bazıları int(10)
varchar(255)
... vs gibi değilutf8
type
yanı data type
sıra @MTK olarak, belki yukarıda bir kopyala yapıştır hatadır "çıktı:" bölümü.
İçin tablolar :
SHOW TABLE STATUS
tüm tabloları listeler.
Şunu kullanarak filtrele:
SHOW TABLE STATUS where name like 'table_123';
TABLE_SCHEMA SEÇ, TABLO İSMİ, DEFAULT_CHAR_SET OLARAK CCSA.CHARACTER_SET_NAME, SÜTUN ADI, column_type, C.CHARACTER_SET_NAME BİLGİ TARAFINDAN BİLGİ. C KULLANIM OLARAK BİLGİLER (TABLE_SCHEMA, TABLE_NAME) CCSA OLARAK information_schema.COLLATION_CHARACTER_SET_APPLICABILITY KATILIN AÇIK (T.TABLE_COLLATION = CCSA.COLLATION_NAME) NEREDE TABLE_SCHEMA = SCHEMA () VE C.DATA_TYPE IN ('enum', 'varchar', 'char', 'metin', 'orta metin', 'uzun metin') SİPARİŞ TABLE_SCHEMA, TABLO İSMİ, SÜTUN ADI ;
Her zaman bakarım SHOW CREATE TABLE mydatabase.mytable
.
Veritabanı için, bakmanız gerekir SELECT DEFAULT_CHARACTER_SET_NAME FROM information_schema.SCHEMATA
.
select default_character_set_name from information_schema.schemata
yeterli değil çünkü hangi satırın hangi veritabanı ile ilişkili olduğunu söyleyemezsiniz. Kullanım select default_character_set_name,schema_name from information_schema.schemata
basitçe veya: select*from information_schema.schemata
.
SELECT * FROM information_schema.SCHEMATA WHERE SCHEMA_NAME = '<database-name>' \G;
Ve harika çalıştı :) Teşekkürler!
Veritabanının varsayılan harmanlamasını görmek için:
USE db_name;
SELECT @@character_set_database, @@collation_database;
Tablonun harmanlamasını görmek için:
SHOW TABLE STATUS where name like 'table_name';
Sütunların harmanlamasını görmek için:
SHOW FULL COLUMNS FROM table_name;
İçin veritabanları :
SELECT SCHEMA_NAME 'database', default_character_set_name 'charset', DEFAULT_COLLATION_NAME 'collation' FROM information_schema.SCHEMATA;
Örnek çıktı:
mysql> SELECT SCHEMA_NAME 'database', default_character_set_name 'charset', DEFAULT_COLLATION_NAME 'collation' FROM information_schema.SCHEMATA;
+----------------------------+---------+--------------------+
| database | charset | collation |
+----------------------------+---------+--------------------+
| information_schema | utf8 | utf8_general_ci |
| drupal_demo1 | utf8 | utf8_general_ci |
| drupal_demo2 | utf8 | utf8_general_ci |
| drupal_demo3 | utf8 | utf8_general_ci |
| drupal_demo4 | utf8 | utf8_general_ci |
| drupal_demo5 | latin1 | latin1_swedish_ci |
...
+----------------------------+---------+--------------------+
55 rows in set (0.00 sec)
mysql>
İçin veritabanları :
SHOW CREATE DATABASE "DB_NAME_HERE";
Bir Veritabanı (MySQL) oluştururken, varsayılan karakter kümesi / harmanlama her zaman LATIN'dir, bunun yerine başlangıçta veritabanınızı oluştururken farklı bir tane seçtiniz
latin1_swedish_ci
MySQL'in yaratıcısı Monty Widenius'un İsveçli olduğunu ve başladığında olması gerektiği gibi Büyük Resim olarak düşünmediğini biliyor .
Birçoğunun daha önce yazdığı gibi, sütun bilgilerini almak için TAM KOLONLARI GÖSTER tercih edilen yöntem olmalıdır. Eksik olan, meta veri tablolarına doğrudan ulaşmadan bundan sonra karakter seti almanın bir yoludur:
SHOW FULL COLUMNS FROM my_table WHERE Field = 'my_field'
SHOW COLLATION WHERE Collation = 'collation_you_got'
SHOW CREATE TABLE