文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么在MySQL中利用SQL语句修改表名

2023-06-14 10:26

关注

这篇文章将为大家详细讲解有关怎么在MySQL中利用SQL语句修改表名,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

rename table这个SQL语句来修改表名的基本语法是:

RENAME TABLE <旧表名> TO <新表名>;

我们来把test表修改为test1表。

首先查看一下当前数据库中有哪些表。

mysql> show tables;+-------------------+| Tables_in_cainiao |+-------------------+| test       || test2       |+-------------------+2 rows in set (0.00 sec)

执行重命名操作,把test修改为test1。

mysql> rename table test to test1;Query OK, 0 rows affected (0.08 sec)

再次查看一下结果。

mysql> show tables;+-------------------+| Tables_in_cainiao |+-------------------+| test1       || test2       |+-------------------+2 rows in set (0.00 sec)

补充:MySQL中修改表名,表属性名等的操作

alter table 表名 change 原列名 新列名 类型; --修改表的列属性名

alter table 表名 modify 列名 类型 ; --修改表的类类型

alter table 表名 drop 列名; --删除表的某一列

alter table 表名 add 列名 类型;--添加某一列

alter table 表名 rename 新表名; --修改表名

补充:MYSQL批量修改表前缀与表名sql语句

修改表名

ALTER TABLE 原表名 RENAME TO 新表名;

一句SQL语句只能修改一张表

show tables;

怎么在MySQL中利用SQL语句修改表名

SELECT  CONCAT(    'ALTER TABLE ',    table_name,    ' RENAME TO db_',    substring(table_name, 4),    ';'  )FROM  information_schema. TABLESWHERE  table_name LIKE 'ct%';

怎么在MySQL中利用SQL语句修改表名

批量复制一下到Notepad++中,只保留sql语句,再复制到mysql中执行

php脚本批量修改mysql数据库表前缀

<?php//设置好相关信息$dbserver='localhost';//连接的服务器一般为localhost$dbname='corethink';//数据库名$dbuser='root';//数据库用户名$dbpassword='root';//数据库密码$old_prefix='ct_';//数据库的前缀$new_prefix='new_';//数据库的前缀修改为if ( !is_string($dbname) || !is_string($old_prefix)|| !is_string($new_prefix) ){  return false;}  if (!mysql_connect($dbserver, $dbuser, $dbpassword)) {   print 'Could not connect to mysql';  exit;}//取得数据库内所有的表名$result = mysql_list_tables($dbname);if (!$result){  print "DB Error, could not list tablesn";  print 'MySQL Error: ' . mysql_error();  exit;}//把表名存进$data while ($row = mysql_fetch_row($result)) {  $data[] = $row[0];}//过滤要修改前缀的表名foreach($data as $k => $v){  $preg = preg_match("/^($old_prefix{1})([a-zA-Z0-9_-]+)/i", $v, $v1);  if($preg){    $tab_name[$k] = $v1[2];  }}if($preg){           foreach($tab_name as $k => $v){    $sql = 'RENAME TABLE `'.$old_prefix.$v.'` TO `'.$new_prefix.$v.'`';    mysql_query($sql);  }  print 数据表前缀:.$old_prefix."<br>".已经修改为:.$new_prefix."<br>";  }else{ print 您的数据库表的前缀.$old_prefix.输入错误。请检查相关的数据库表的前缀;   if ( mysql_free_result($result) ){    return true;  }}?>

由于mysql_list_tables方法已经过时,运行以上程序时会给出方法过时的提示信息

Deprecated: Function mysql_list_tables() is deprecated in … on line xxx

在php.ini中设置error_reporting,不显示方法过时提示信息

error_reporting = E_ALL & ~E_NOTICE & ~E_DEPRECATED

批量删除表

SELECT  CONCAT(    'drop table ',    table_name,    ';'  )FROM  information_schema. TABLESWHERE  table_name LIKE 'uc_%';

关于怎么在MySQL中利用SQL语句修改表名就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯