mysql数据表的基本操作:表结构操作,字段操作

本节介绍:

表结构操作

  • 创建数据表、
  • 查看数据表和查看字段、
  • 修改数据表结构
  • 删除数据表

字段操作

  • 新增字段、
  • 修改字段数据类型、位置或属性、
  • 重命名字段
  • 删除字段

首发时间:2018-02-18  21:31


表结构操作

创建数据表:

  • 语法  :

create table [if not exists] 表名(
字段名字 数据类型,
字段名字 数据类型
)[表选项];
  • 表选项  :

字符集:charset表中存储数据的字符集

校对集:colloate表中用来校对数据的校对集

存储引擎  :engine存储数据的存储引擎

  • 使用示例  :

-- 建表之前必须指定数据库,使用use ,或者显式指定
create table if not exists mydatabase.student(
name varchar(20),
sex varchar(20),
number varchar(20),
age int
)charset utf8;
--
use mydatabase;
create table if not exists class(
name varchar(20),
room varchar(20)
)charset utf8;

------------
use mydatabase;
create table if not exists class(
name varchar(20),
room varchar(20)
);
  • 补充说明  :

    • if not exists 是先检查是否存在同名的表,如果存在,则不执行后面的创建语句。
    • 如果没有指定表选项,将使用默认的,比如mysql默认的存储引擎是innodb

查看数据表  :

查看数据表可以查看已有数据表、数据表的字段信息

  • 语法  :
-- 查看所有表
show tables;
-- 查看部分表
show tables like ‘模糊匹配‘;
-- 查看表的创建语句
show create table 数据表名;
-- 旋转查看结构
show create table 数据表名\G;
-- 查看表结构:查看表中的字段信息:
Desc/desc 表名;
describe 表名;
show columns from 表名;
  • 通配符:

_匹配单个字符

%匹配多个字符

  • 使用示例  :
show tables;
show tables like ‘my%‘;
show create table student;
show create table student\G;
desc student;
describe student;
show columns from student;

图例:

  1. show create table student;跟show create table sudent\G;

Desc/describe /show columns from 表名;

修改数据表结构  :

修改表本身只能修改表名和表选项。

  • 语法  :
-- 修改表名:
rename table 老表名 to 新表名;
--修改表选项:
Alter table 表名 表选项 [=] 值;
  • 使用示例  :
rename table student to my_student;
rename table class to my_class;
--
Alter table my_student charset gbk;
Alter table my_collation_bin collate =utf8_bin;

删除数据表  :

  • 语法  :
Drop table 表名1,表名2...;
  • 使用示例  :
drop table demo;
drop table demodata;
  • 补充说明  :

    • 删除不可恢复


字段操作  :

新增字段  :

新增字段是在表存在的基础上新增字段

  • 语法  :
Alter table 表名 add [column] 字段名 数据类型 [列属性] [位置];
  • 使用示例  :
Alter table 表名 add [column] 字段名 数据类型 [列属性] [位置];
Alter table demo add column id int first;
Alter table demo add id int;
Alter table demo add  class int after age;
Alter table demo add  number int not null after age;
  • 补充说明  :

    • 位置常用语法:first 字段名,after 字段名 ;
    • 列属性:主键,空 等;

修改字段  :

修改字段一般都是修改字段数据类型或者字段属性

  • 语法  :
Alter table 表名 modify 字段名 数据类型 [属性] [位置];
  • 使用示例  :
Alter table my_student modify number char(10) after id;
Alter table demo modify  number int null ;
--
alter table student modify name varchar(20) not null;

--
alter table student modify name varchar(20) not null primary key;
  • 补充说明  :

    • 字段名和数据类型是必填的,属性和位置是选填的。
    • 如果字段本身带着属性的,那么必须带上原来的,否则会被去除掉;如果需要在原有属性的基础上添加新的属性,则在填入时,那么在带上原有属性的基础上加上新的属性即可

重命名字段  :

  • 语法  :
Alter table 表名 change 旧字段 新字段 数据类型 [属性] [位置];
  • 使用示例  :
alter table demo change class room varchar(10);
Alter table my_student change sex gender varchar(10);
  • 补充说明  :

    • 数据类型是必填的,但可以是新的【重名字段可以顺便改数据类型】
    • 改名的同时也能修改字段的数据类型,属性和位置。【如果字段带有属性,重命名字段时可以不带上】

删除字段  :

  • 语法  :
Alter table 表名 drop 字段名;
  • 使用示例  :
Alter table my_student drop age;
alter table demo drop room;
  • 补充说明  :

    • 删除需谨慎,删除字段代表着将该字段下的所有数据都将删除。

原文地址:https://www.cnblogs.com/progor/p/8453351.html

时间: 2024-10-16 20:15:18

mysql数据表的基本操作:表结构操作,字段操作的相关文章

恢复MySQL数据到误删的表之前的数据

一.演示环境说明: 系统CentOS Linux release 7.2.1511 (Core) X_86 64位最小化安装mysql版本是官方二进制版本5.7.22-22,mysql采用的是二进制安装,单机上开启2个mysql实例,mysql实例要开启定时器event_scheduler=ON. 而且2个mysql实例都要开启Gtidxtrabackup 采用的是rpm包安装,版本是version 2.4.13 MySQL备份方式采用每天一次全量备份和binlog增量备份 二.模拟删除库,进行

MYSQL数据切分(分库分表),读写分离和主从复制

参考1 参考2 对于一个大型的互联网应用,每天几十亿的PV无疑对数据库造成了相当高的负载.对于系统的稳定性和扩展性造成了极大的问题.通过数据切分来提高网站性能,横向扩展数据层已经成为架构研发人员首选的方式. 数据切分:可以降低单台机器的负载,同时最大限度的降低了宕机造成的损失: 负载均衡策略:可以降低单台机器的访问负载,降低宕机的可能性: 集群方案:解决了数据库宕机带来的单点数据库不能访问的问题: 读写分离策略:最大限度了提高了应用中读取数据的速度和并发量: 这里主要谈及数据切分和其相关数据库优

递归解决根据父节点遍历权限树菜单的问题--------mysql数据中的树表

本人几乎没写过博客,感觉要学的知识和要做的事情太多,没时间.但发现用博客记录自己学习心得非常好,就抽时间写点,供自己以后参考也分享给某些需要的人,我水平有限,请多指教! 最近在独自尝试开发一个小型的oa系统以巩固下自己对java ssh框架的学习.这里记录下开发中的一些心得体会. 我把系统菜单设计成树,用一张表存储,各个菜单项之间是父子关系,当我们要根据用户权限去数据库中取菜单项时,发现sql语句不好解决.之前在网上查看了一些帖子博文,发现oracle中有对这个需求有专门的sql语句:类似这样

MySQL数据表的基本操作二:表结构查看、修改与表操作

一.查看数据表结构 1) 查看表基本结构语句 DESCRIBE 语法:DESCRIBE 表名; 示例: mysql> DESCRIBE product; +--------------+--------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +--------------+--------------+------+-----+---------

mysql(三) 数据表的基本操作操作

mysql(三) 数据表的基本操作操作 创建表,曾删改查,主键,外键,基本数据类型. 1. 创建表 create table 表名( 列名 类型 是否可以为空, 列名 类型 是否可以为空 )ENGINE=InnoDB DEFAULT CHARSET=utf8 例如: 类型解释: 是否可以为空: 是否可空,null表示空,非字符串 not null - 不可空 null - 可空 默认值设置 默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值 create table t

mysql数据表的基本操作

好久没梳理下Mysql基础命令了.今天抽空整理了下,虽然很简单...但是还是有必要巩固下基础滴啦 1.创建表:之前需要use database database_name 然后create table 表名(): 例:创建员工表tb_employee1,结构如下表所示 字段名称 数据类型 备注 id int(11) 员工编号 name varchar(25) 员工名称 depld int(11) 所在部门编号 salary float 工资 mysql> create database aa;

mysql数据表操作&库操作

首先登陆mysql:mysql -uroot -proot -P3306 -h127.0.0.1 查看所有的库:show databases; 进入一个库:use database; 显示所在的库:select database(); 开始进行数据表操作: 1,创建数据表:create table user( id smallint unsigned aotu_crement not null primary key,  //id,整型无符号位非空主键 idNum varchar(20) uni

MySQL删除表及删除表数据操作

MySQL删除表和删除表的数据是常见的操作,使用关键词 DELETE FROM 表名的结构模式,下面详细讲述删除表和删除表数据. 1,删除数据库里面的表 DELETE FROM employees; 2,删除数据库里面的表数据 DELETE FROM huthon WHERE id = 4; 注意删除多个id 应该用 id in (4,5,6) 模式 文章来自:http://www.huthon.cn/ 原文地址:http://blog.51cto.com/13959155/2176543

navicat如何导出mysql数据表结构

我们在创建数据库时会对字段进行设置,比如类型.长度等,如果字段多的话一个个设置非常麻烦,可以从其他地方已有的表导入数据表结构,怎么操作呢?我们拿navicat导出mysql数据表结构为例: 1.点击“工具”–>数据传输. 2.在弹出的窗口里左边可以选择需要导出的表,右边选择连接或文件(我要导出sql文件,所以我选的是文件)选择导出的位置. 3.如果只是想导出表结构而不需要表的数据,那么点击“高级”–>把“插入记录”前的勾去掉.如果需要导出数据,那么默认打勾就可以, 4.点击开始,直到进度条走到