IT story

데이터베이스, 테이블, 열의 데이터 정렬을 변경하는 방법은 무엇입니까?

hot-time 2020. 5. 19. 08:11
반응형

데이터베이스, 테이블, 열의 데이터 정렬을 변경하는 방법은 무엇입니까?


데이터베이스가 latin1_general_ci지금 있고 데이터 정렬을로 변경하고 싶습니다 utf8mb4_general_ci.

PhpMyAdmin에 데이터베이스, 테이블, 열의 데이터 정렬을 변경하는 설정이 있습니까? 하나씩 변경하지 않고?


각 테이블을 개별적으로 변환해야합니다.

ALTER TABLE mytable CONVERT TO CHARACTER SET utf8mb4 

(이것도 열을 변환합니다) 또는로 데이터베이스를 latin1내보내고로 가져옵니다 utf8mb4.


OP가 요청 한대로 여기에 기여하고 있습니다.

데이터베이스, 테이블, 열의 데이터 정렬을 변경하는 방법은 무엇입니까?

선택한 답변은 표 수준에서만 표시됩니다.


데이터베이스 전체 변경 :

ALTER DATABASE <database_name> CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

테이블 당 변경 :

ALTER TABLE <table_name> CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

테이블 수준에서 열에 대해서도 변경되므로 테이블 수준에서 변경하는 것이 좋습니다. 특정 열에 대한 변경은 특정 사례에 대한 것입니다.

특정 열의 데이터 정렬 변경 :

ALTER TABLE <table_name> MODIFY <column_name> VARCHAR(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

PHP 스크립트를 실행할 수 있습니다.

               <?php
                   $con = mysql_connect('localhost','user','password');
                   if(!$con) { echo "Cannot connect to the database ";die();}
                   mysql_select_db('dbname');
                   $result=mysql_query('show tables');
                   while($tables = mysql_fetch_array($result)) {
                            foreach ($tables as $key => $value) {
                             mysql_query("ALTER TABLE $value CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci");
                       }}
                   echo "The collation of your database has been successfully changed!";
                ?>

사용할 수있는 테이블의 데이터 정렬을 개별적으로 변경하려면

ALTER TABLE mytable CONVERT TO CHARACTER SET utf8

전체 데이터베이스에 대한 기본 데이터 정렬을 설정하려면

ALTER DATABASE  `databasename` DEFAULT CHARACTER SET utf8 COLLATE utf8_bin

그렇지 않으면,

고토 PhpMyAdmin-> Operations (작업)> 정렬.

거기에 모든 기존 데이터 정렬이 포함 된 선택 상자가 있습니다. 여기에서 데이터 정렬을 변경할 수 있습니다. 따라서 여기에 데이터베이스 테이블 뒤에 새 열을 만드는 동안이 데이터 정렬이 이어집니다. 새 열을 만드는 동안 선택 데이터 정렬이 필요하지 않습니다.


다음 쿼리는 모든 테이블의 모든 해당 열에 대한 데이터 정렬을 특정 유형으로 변경하는 ALTER 쿼리를 생성합니다 (아래 예에서는 utf8_general_ci).

SELECT concat
        (
            'ALTER TABLE ', 
                t1.TABLE_SCHEMA, 
                '.', 
                t1.table_name, 
                ' MODIFY ', 
                t1.column_name, 
                ' ', 
                t1.data_type, 
                '(' , 
                    CHARACTER_MAXIMUM_LENGTH, 
                ')', 
                ' CHARACTER SET utf8 COLLATE utf8_general_ci;'
        )
from 
    information_schema.columns t1
where 
    t1.TABLE_SCHEMA like 'you_db_name_goes_here' AND
    t1.COLLATION_NAME IS NOT NULL AND
    t1.COLLATION_NAME NOT IN ('utf8_general_ci');

phpMyAdmin 실행 >> 데이터베이스 선택 >> 테이블 선택 >> "테이블 옵션"섹션의 "작업"탭으로 이동 >> >> 드롭 다운 목록에서 데이터 정렬을 선택할 수 있습니다 >> 그리고 {Go}를 누르면 화면 상단에 다음과 같은 메시지가 나타납니다.

SQL 쿼리가 성공적으로 실행되었습니다

그리고 대본

ALTER TABLE `tableName` CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci 

그러나 기존 열의 데이터 정렬은 변경되지 않습니다. 이를 위해이 스크립트를 사용할 수 있습니다 (이 스크립트는 phpMyAdmin에서도 제공됨)

ALTER TABLE  `tableName` CHANGE  `Name`  `Name` VARCHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL

여러 수준에서 기본 데이터 정렬을 설정할 수 있습니다.

http://dev.mysql.com/doc/refman/5.0/en/charset-syntax.html

1) 클라이언트 2) 서버 기본값 3) 데이터베이스 기본값 4) 테이블 기본값 5) 열


나는 놀랐고, 그래서 여기에 와서보고 훌륭하게 유지 관리 된 Interconnect / it SAFE SEARCH 및 REPLACE ON DATABASE 스크립트에는 테이블을 utf8 / 유니 코드로 변환하고 심지어 innodb로 변환하는 옵션이 있음을보고해야했습니다. . 데이터베이스 기반 웹 사이트 (Wordpress, Drupal, Joomla 등)를 한 도메인에서 다른 도메인으로 마이그레이션하는 데 일반적으로 사용되는 스크립트입니다.

상호 연결 스크립트 버튼


다음과 같이 PHP 스크립트를 통해 모든 테이블의 CHARSET 및 COLLATION을 변경할 수 있습니다. 나는 hkasera의 대답을 좋아하지만 문제는 각 테이블에서 쿼리가 두 번 실행된다는 것입니다. 이 코드는 mysql 대신 MySqli를 사용하고 이중 쿼리 방지를 제외하고 거의 동일합니다. 투표 할 수 있다면 hkasera의 답변에 투표했을 것입니다.

<?php
$conn1=new MySQLi("localhost","user","password","database");
if($conn1->connect_errno){
    echo mysqli_connect_error();
    exit;
}
$res=$conn1->query("show tables") or die($conn1->error);
while($tables=$res->fetch_array()){
    $conn1->query("ALTER TABLE $tables[0] CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci") or die($conn1->error);
}
echo "The collation of your database has been successfully changed!";

$res->free();
$conn1->close();

?>

이 코드를 스크립트 파일에 간단하게 추가 할 수 있습니다

//Database Connection
$host = 'localhost';
$db_name = 'your_database_name';
$db_user =  'your_database_user_name';
$db_pass = 'your_database_user_password';

$con = mysql_connect($host,$db_user,$db_pass);

if(!$con) { echo "Cannot connect to the database ";die();}

  mysql_select_db($db_name);

  $result=mysql_query('show tables');

  while($tables = mysql_fetch_array($result)) {
    foreach ($tables as $key => $value) {
    mysql_query("ALTER TABLE $value CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci");
  }
}

echo "The collation of your database has been successfully changed!";

여기에서 읽었습니다. 각 테이블을 수동으로 변환해야하지만 사실이 아닙니다. 저장 프로 시저로 수행하는 방법은 다음과 같습니다.

DELIMITER $$

DROP PROCEDURE IF EXISTS changeCollation$$

-- character_set parameter could be 'utf8'
-- or 'latin1' or any other valid character set
CREATE PROCEDURE changeCollation(IN character_set VARCHAR(255))
BEGIN
DECLARE v_finished INTEGER DEFAULT 0;
DECLARE v_table_name varchar(255) DEFAULT "";
DECLARE v_message varchar(4000) DEFAULT "No records";

-- This will create a cursor that selects each table,
-- where the character set is not the one
-- that is defined in the parameter

DECLARE alter_cursor CURSOR FOR SELECT DISTINCT TABLE_NAME
FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = DATABASE()
AND COLLATION_NAME NOT LIKE CONCAT(character_set, '_%');

-- This handler will set the value v_finished to 1
-- if there are no more rows

DECLARE CONTINUE HANDLER
FOR NOT FOUND SET v_finished = 1;

OPEN alter_cursor;

-- Start a loop to fetch each rows from the cursor
get_table: LOOP

-- Fetch the table names one by one
FETCH alter_cursor INTO v_table_name;

-- If there is no more record, then we have to skip
-- the commands inside the loop
IF v_finished = 1 THEN
LEAVE get_table;
END IF;

IF v_table_name != '' THEN

IF v_message = 'No records' THEN
SET v_message = '';
END IF;

-- This technic makes the trick, it prepares a statement
-- that is based on the v_table_name parameter and it means
-- that this one is different by each iteration inside the loop

SET @s = CONCAT('ALTER TABLE ',v_table_name,
' CONVERT TO CHARACTER SET ', character_set);
PREPARE stmt FROM @s;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

SET v_message = CONCAT('The table ', v_table_name ,
' was changed to the default collation of ', character_set,
'.\n', v_message);

SET v_table_name = '';

END IF;
-- Close the loop and the cursor
END LOOP get_table;
CLOSE alter_cursor;

-- Returns information about the altered tables or 'No records'
SELECT v_message;

END $$

DELIMITER ;

절차가 생성되면 간단히 호출하십시오.

CALL changeCollation('utf8');

자세한 내용은이 블로그 를 참조하십시오 .


스키마에서 기본 문자 집합을 업데이트하려는 경우 :

 ALTER SCHEMA MYSCHEMA DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_unicode_ci;

I used the following shell script. It takes database name as a parameter and converts all tables to another charset and collation (given by another parameters or default value defined in the script).

#!/bin/bash

# mycollate.sh <database> [<charset> <collation>]
# changes MySQL/MariaDB charset and collation for one database - all tables and
# all columns in all tables

DB="$1"
CHARSET="$2"
COLL="$3"

[ -n "$DB" ] || exit 1
[ -n "$CHARSET" ] || CHARSET="utf8mb4"
[ -n "$COLL" ] || COLL="utf8mb4_general_ci"

echo $DB
echo "ALTER DATABASE $DB CHARACTER SET $CHARSET COLLATE $COLL;" | mysql

echo "USE $DB; SHOW TABLES;" | mysql -s | (
    while read TABLE; do
        echo $DB.$TABLE
        echo "ALTER TABLE $TABLE CONVERT TO CHARACTER SET $CHARSET COLLATE $COLL;" | mysql $DB
    done
)

Just run this SQL. Change your COLLATION to what you need and databaseName.

SELECT CONCAT("ALTER TABLE ", TABLE_SCHEMA, '.', TABLE_NAME," COLLATE utf8_general_ci;") AS    ExecuteTheString
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_SCHEMA="databaseName"
AND TABLE_TYPE="BASE TABLE";

Quick way - export to SQL file, use search and replace to change the text you need to change. Create new database, import the data and then rename the old database and the new one to the old name.


My solution is a combination of @Dzintars and @Quassnoi Answer.

SELECT CONCAT("ALTER TABLE ", TABLE_SCHEMA, '.', TABLE_NAME," CONVERT TO CHARACTER SET utf8mb4 ;") AS    ExecuteTheString
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_SCHEMA="<your-database>"
AND TABLE_TYPE="BASE TABLE";

By using CONVERT TO, this generates a scripts, which converts all the Tables of <your-database> to your requested encoding. This also changes the encoding of every column!


I've just written a bash script to find all tables in a given database and covert them (and its columns).

스크립트는 여기에서 사용할 수 있습니다 : https://github.com/Juddling/mysql-charset

참고 URL : https://stackoverflow.com/questions/1294117/how-to-change-collation-of-database-table-column

반응형