当前位置:  数据库>mysql

MySQL学习笔记5:修改表(alter table)

    来源: 互联网  发布时间:2014-10-07

    本文导语:  我们在创建表的过程中难免会考虑不周,因此后期会修改表修改表需要用到alter table语句 修改表名 代码如下: mysql> alter table student rename person; Query OK, 0 rows affected (0.03 sec) 这里的student是原名,person是修改过后的名字 用rename来...

我们在创建表的过程中难免会考虑不周,因此后期会修改表修改表需要用到alter table语句
修改表名
代码如下:

mysql> alter table student rename person;
Query OK, 0 rows affected (0.03 sec)

这里的student是原名,person是修改过后的名字
用rename来重命名,也可以使用rename to
修改字段的数据类型
代码如下:

mysql> alter table person modify name varchar(20);
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

此处modify后面的name为字段名,我们将原来的varchar(25)改为varchar(20)
修改字段名
代码如下:

mysql> alter table person change stu_name name varchar(25);
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

这里stu_name是原名,name是新名
需要注意的是不管改不改数据类型,后面的数据类型都要写
如果不修改数据类型只需写成原来的数据类型即可
tips:我们同样可以使用change来达到modify的效果,只需在其后写一样的字段名
增加无完整性约束条件的字段
代码如下:

mysql> alter table person add sex boolean;
Query OK, 0 rows affected (0.21 sec)
Records: 0 Duplicates: 0 Warnings: 0

此处的sex后面只跟了数据类型,而没有完整性约束条件
增加有完整性约束条件的字段
代码如下:

mysql> alter table person add age int not null;
Query OK, 0 rows affected (0.17 sec)
Records: 0 Duplicates: 0 Warnings: 0

地处增加了一条age字段,接着在后面加上了not null完整性约束条件
在表头添加字段
代码如下:

mysql> alter table person add num int primary key first;
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

默认情况下添加字段都是添加到表尾,在添加语句后面加上first就能添加到表头
在指定位置添加字段
代码如下:

mysql> alter table person add birth date after name;
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

这里添加一条新字段放在name字段后面
tps:表中字段的排序对表不会有什么影响,不过更合理的排序能便于理解表
删除字段
代码如下:

mysql> alter table person drop sex;
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

和前面删除表或数据库一样,这里也需要用drop
不同的是,删除字段还要用alter table跟着表名
修改字段到第一个位置
代码如下:

mysql> alter table person modify id int first;
Query OK, 0 rows affected (0.20 sec)
Records: 0 Duplicates: 0 Warnings: 0

first在前面已经讲过,此处要注意的是字段后面要写数据类型
修改字段到指定位置
代码如下:

mysql> alter table person modify name varchar(25) after id;
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

我们把name字段放到了id后面,此处的varchar(25)要写全,varchar不行
建议操作以上步骤之前都先desc table
修改表的存储引擎
代码如下:

mysql> alter table user rename person;
Query OK, 0 rows affected (0.05 sec)

这里先不具体讲各个存储引擎的特点,内容比较多
修改完之后别忘了使用show create table语句查看,第三节有写用法
tips:如果表中已存在很多数据,不要轻易修改存储引擎
增加表的外键
代码如下:

mysql> alter table score add constraint fk foreign key(stu_id) references student(id);
Query OK, 10 rows affected (0.18 sec)
Records: 10 Duplicates: 0 Warnings: 0

这里只需使用add增加即可,后面的语法参见第四节中的外键设置
删除表的外键约束
代码如下:

mysql> alter table student3 drop foreign key fk;
Query OK, 0 rows affected (0.18 sec)
Records: 0 Duplicates: 0 Warnings: 0

由于基本的表结构描述无法显示外键,所以在进行此操作前最好使用show create table查看表
这里的fk就是刚刚设置的外键
需要注意的是:如果想要删除有关联的表,那么必先删除外键
删除外键后,原先的key变成普通键
至于删除表的操作,在第三节有写,设置外键在第四节也有写如果创建表的时候没有设置外键,可使用上面的方法

    
 
 

您可能感兴趣的文章:

  • mysql中如何查看最大连接数(max_connections)和修改最大连接数
  • mysql修改用户密码的方法和mysql忘记密码的解决方法
  • 修改mysql5.5默认编码(图文步骤修改为utf-8编码)
  • 修改mysql密码与忘记mysql密码的处理方法
  • mysql root用户的密码修改和消除
  • 怎么修改suse下mysql的编码方式
  • mysql日志文件在哪 如何修改MySQL日志文件位置
  • linux下的mysql密码破解与修改
  • linux + apache+php+mysql 修改那一行?
  • 解析mysql修改为utf8后仍然有乱码的问题
  • centos mysql 修改数据库目录
  • 怎么修改linux centOS的mysql 的数据存储路径
  • MySQL修改配置 区分大小写
  • VPS下修改MySQL root用户密码的方法
  • MYSQL 修改root密码命令小结
  • mysql字符集和数据库引擎修改方法分享
  • mysql修改密码问题
  • dos或wamp下修改mysql密码的具体方法
  • 如何修改WAMP中mysql默认空密码的方法
  • MYSQL基础之连接MYSQL、修改密码、添加用户
  • 如何修改mysql数据库的max_allowed_packet参数
  • MySQL定时器EVENT学习笔记
  • MySQL笔记之别名的使用
  • mysql 数据库基础笔记
  • 用VirtualBox构建MySQL测试环境的笔记
  • MySQL笔记之函数查询的使用
  • MySQL学习笔记2:数据库的基本操作(创建删除查看)
  • MySQL 数据库设计复习笔记及项目实战
  • 高性能MySQL读书笔记 找出谁持有锁
  • MYSQL的select 学习笔记
  • MySQL学习笔记3:表的基本操作介绍
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql动态游标学习(mysql存储过程游标)
  • 与MSSQL对比学习MYSQL的心得(三)--查看字段的长度
  • 学习mysql之后的一点总结(基础)
  • PHP MySQL Where子句学习
  • 与MSSQL对比学习MYSQL的心得(四)--BLOB数据类型
  • 与MSSQL对比学习MYSQL的心得(二)--显示宽度
  • mysql 常见命令和学习心得
  • MySQL触发器学习总结
  • 在linux下安装mysql出错的原因,学习的机会、得分的机会、奉献的计划
  • Oracle与MySQL学习体会比较
  • PHP mysql数据库操作实例学习
  • java连接mysql数据库学习示例
  • 从一个MySQL的例子来学习查询语句
  • JAVA/JSP学习系列之六(MySQL翻页例子)
  • PHP学习散记 2012_01_07(MySQL)
  • JAVA/JSP学习系列之八(改写MySQL翻页例子)
  • 与MSSQL对比学习MYSQL的心得(一)--基本语法
  • Mysql源码学习笔记 偷窥线程
  • 与MSSQL对比学习MYSQL的心得(五)--运算符
  • 与MSSQL对比学习MYSQL的心得(八)--插入 更新 删除
  • Mysql查询错误:ERROR:no query specified原因
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • php安装完成后如何添加mysql扩展
  • MySQL 重装MySQL后, mysql服务无法启动
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • MySQL Workbench的下载安装与使用教程
  • 求解释: useradd -g mysql mysql -d /home/mysql -s /sbin/nologin
  • php中内置的mysql数据库连接驱动mysqlnd简介及mysqlnd的配置安装方式


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3