加入收藏 | 设为首页 | 会员中心 | 我要投稿 源码网 (https://www.900php.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL追加注释或者大量修改注释的办法

发布时间:2022-01-16 10:51:10 所属栏目:MySql教程 来源:互联网
导读:这篇文章主要讲解了MySQL追加注释或者大量修改注释的方法,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习MySQL追加注释或者大量修改注释的方法吧! MySQL 5.6.14 之前一个项目比较仓促,开发给的建表语句没
         这篇文章主要讲解了“MySQL追加注释或者大量修改注释的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL追加注释或者大量修改注释的方法”吧!
 
MySQL 5.6.14
 
      之前一个项目比较仓促,开发给的建表语句没有注释.
      现在要补全注释信息.
      但是MySQL后期追加注释比较麻烦
      需要使用modify语法。
 
只要不小心写错一点,就可能导致表结构的变更,而不是注释的变更.
 
实验表如下:
 
create table t(  
    c1 int primary key auto_increment,  
    c2 char(20) not null default 'c2'  comment 'c2的注释',  
    c3 date default '2016-01-25' comment 'date类型测试',  
    c4 varchar(20) not null default '' ,  
    c5 bigint ,  
    c6 text comment 'text测试',  
    c7 timestamp not null default on update not null default now()  
);  
 
 
通过如下的SQL,解析元数据信息,可以直接显示modify的内容.
追加或者修改注释之后,执行语句即可.
这样可以避免人为的失误.
 
SELECT     
concat(    
    'alter table ',     
    table_schema, '.', table_name,     
    ' modify column ', column_name, ' ', column_type, ' ',     
    if(is_nullable = 'YES', ' ', 'not null '),     
    if(column_default IS NULL, '',     
        if(    
            data_type IN ('char', 'varchar')     
            OR     
            data_type IN ('date', 'datetime', 'timestamp') AND column_default != 'CURRENT_TIMESTAMP',     
            concat(' default ''', column_default,''''),     
            concat(' default ', column_default)    
        )    
    ),     
    if(extra is null or extra='','',concat(' ',extra)),  
    ' comment ''', column_comment, ''';'    
) s    
FROM information_schema.columns    
WHERE table_schema = 'test'    
    AND table_name = 't'   
 
 
以实验表为例,生成的modify语句如下.
 
 
alter table test.t modify column c1 int(11) not null  auto_increment comment '';  
alter table test.t modify column c2 char(20) not null  default 'c2' comment 'c2的注释';  
alter table test.t modify column c3 date   default '2016-01-25' comment 'date类型测试';  
alter table test.t modify column c4 varchar(20) not null  default '' comment '';  
alter table test.t modify column c5 bigint(20)   comment '';  
alter table test.t modify column c6 text   comment 'text测试';  
alter table test.t modify column c7 timestamp not null  default on update '';  
alter table test.t modify column c8 datetime not null  default '';  
感谢各位的阅读,以上就是“MySQL追加注释或者大量修改注释的方法”的内容了,经过本文的学习后,相信大家对MySQL追加注释或者大量修改注释的方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。

(编辑:源码网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读