重命名mysql数据库的五个方法

 我来答
百度网友6815b3c0234
2019-06-03 · TA获得超过3740个赞
知道大有可为答主
回答量:3118
采纳率:27%
帮助的人:222万
展开全部
  五个改mysql数据库名的方法:
  1.
RENAME
DATABASE
db_name
TO
new_db_name
  这个。。这个语法在mysql
5.1.7中被添加进来,到了5.1.23又去掉了。据说有可能丢失数据。还是不要用的好。详见:
http://dev.mysql.com/doc/refman/5.1/en/rename-database.html
  2.如果所有表都是MyISAM类型的话,可以改文件夹的名字
  关闭mysqld
  把data目录中的db_name目录重命名为new_db_name
  开启mysqld
  3.重命名所有的表
  CREATE
DATABASE
new_db_name;
  RENAME
TABLE
db_name.table1
TO
new_db_name.table1,
  db_name.table2
TO
new_db_name.table2;
  DROP
DATABASE
db_name;
  4.
mysqldump导出数据再导入
  mysqldump
-uxxxx
-pxxxx
-h
xxxx
db_name
>
db_name_dump.SQL
  mysql
-uxxxx
-pxxxx
-h
xxxx
-e
“CREATE
DATABASE
new_db_name”
  mysql
-uxxxx
-pxxxx
-h
xxxx
new_db_name
<
db_name_dump.SQL
  mysql
-uxxxx
-pxxxx
-h
xxxx
-e
“DROP
DATABASE
db_name”
  5.使用Shell脚本重命名所有的表
  #!/bin/bash
  mysqlconn=”mysql
-u
xxxx
-pxxxx
-S
/var/lib/mysql/mysql.sock
-h
localhost”
  olddb=”db_name”
  newdb=”new_db_name”
  #$mysqlconn
-e
“CREATE
DATABASE
$newdb”
  params=$($mysqlconn
-N
-e
“SELECT
TABLE_NAME
FROM
INFORMATION_SCHEMA.TABLES
WHERE
table_schema=’$olddb’”)
  for
name
in
$params;
do
  $mysqlconn
-e
“RENAME
TABLE
$olddb.$name
to
$newdb.$name”;
  done;
  #$mysqlconn
-e
“DROP
DATABASE
$olddb”
  就是方法3的优化版。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式