Data Definition Language,数据定义语言,用来定义数据库对象(数据库,表,字段) 。

1.数据库操作

1.1数据库操作

1). 查询所有数据库

2). 查询当前数据库

3). 创建数据库


案例:
A. 创建一个itcast数据库, 使用数据库默认的字符集。

create database itcast;


在同一个数据库服务器中,不能创建两个名称相同的数据库,否则将会报错。

可以通过if not exists 参数来解决这个问题,数据库不存在, 则创建该数据库,如果存在,则不创建。

create database if not extists itcast;


B. 创建一个itheima数据库,并且指定字符集

create database itheima default charset utf8mb4

4). 删除数据库


如果删除一个不存在的数据库,将会报错。此时,可以加上参数 if exists ,如果数据库存在,再执行删除,否则不执行删除。

5). 切换数据库

2.表操作

2.1查询创建

1). 查询当前数据库所有表


比如,我们可以切换到sys这个系统数据库,并查看系统数据库中的所有表结构。

use sys;
show tables;

2). 查看指定表结构


通过这条指令,我们可以查看到指定表的字段,字段的类型、是否可以为NULL,是否存在默认值等信息。

3). 查询指定表的建表语句


通过这条指令,主要是用来查看建表语句的,而有部分参数我们在创建表的时候,并未指定也会查询到,因为这部分是数据库的默认值,如:存储引擎、字符集等。

4). 创建表结构


ps:注意: […] 内为可选参数,最后一个字段后面没有逗号
比如,我们创建一张表 tb_user ,对应的结构如下:

那么建表语句为:

createtable tb_user(
id int comment '编号',
name varchar(50) comment '姓名',
age int comment '年龄',
gender varchar(1) comment '性别'
) comment '用户表';

2.2数据类型

MySQL中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型。

1). 数值类型

如:1). 年龄字段 – 不会出现负数, 而且人的年龄不会太大
age tinyint unsigned
2). 分数 – 总分100分, 最多出现一位小数
score double(4,1)123456

2). 字符串类型


char 与 varchar 都可以描述字符串,char是定长字符串,指定长度多长,就占用多少个字符,和字段值的长度无关。而varchar是变长字符串,指定的长度为最大占用长度。相对来说,char的性能会更高些。

如:
1). 用户名 username ------> 长度不定, 最长不会超过50
username varchar(50)
2). 性别 gender ---------> 存储值, 不是男,就是女gender char(1)
3). 手机号 phone --------> 固定长度为11
phone char(11)

3). 日期时间类型

如:
1). 生日字段 birthday
birthday date
2). 创建时间
createtime
createtime datetime

2.3表操作-案例

设计一张员工信息表,要求如下:

  1. 编号(纯数字)
  2. 员工工号 (字符串类型,长度不超过10位)
  3. 员工姓名(字符串类型,长度不超过10位)
  4. 性别(男/女,存储一个汉字)
  5. 年龄(正常人年龄,不可能存储负数)
  6. 身份证号(二代身份证号均为18位,身份证中有X这样的字符)
  7. 入职时间(取值年月日即可)

对应的建表语句:

createtable emp(
id int comment '编号',
workno varchar(10) comment '工号',
name varchar(10) comment '姓名',
gender char(1) comment '性别',
age tinyintunsigned comment '年龄',
idcard char(18) comment '身份证号',
entrydate date comment '入职时间'
) comment '员工表';

SQL语句编写完毕之后,就可以在MySQL的命令行中执行SQL,然后也可以通过 desc 指令查询表结构信息:

2.4表操作-修改

1). 添加字段

ALTER TABLE 表名 ADD  字段名类型 (长度)  [ COMMENT 注释 ]  [ 约束 ];

案例:
为emp表增加一个新的字段”昵称”为nickname,类型为varchar(20)

ALTER TABLE emp ADD nickname varchar(20)  COMMENT '昵称';

2). 修改数据类型

ALTER TABLE表名 MODIFY  字段名 新数据类型 (长度);

3). 修改字段名和字段类型

ALTER TABLE 表名 CHANGE  旧字段名 新字段名 类型 (长度)  [ COMMENT 注释 ]  [ 约束 ];

案例:将emp表的nickname字段修改为username,类型为varchar(30)

ALTER TABLE emp CHANGE  nickname  username varchar(30)  COMMENT '昵称';

4). 删除字段

ALTER TABLE 表名 DROP 字段名;

案例:将emp表的字段username删除

ALTER TABLE emp DROP  username;
ALTERTABLE emp DROP  username;

5). 修改表名

ALTER TABLE 表名 RENAME TO  新表名;

案例:将emp表的表名修改为 employee

ALTERTABLE emp RENAME TO employee;

2.5表操作-删除

1). 删除表

DROP TABLE [ IF  EXISTS ]  表名;

可选项 IF EXISTS 代表,只有表名存在时才会删除该表,表名不存在,则不执行删除操作(如果不加该参数项,删除一张不存在的表,执行将会报错)。
案例:
如果tb_user表存在,则删除tb_user表

DROP TABLE IF  EXISTS  tb_user

2). 删除指定表, 并重新创建表

TRUNCATE  TABLE表名;
TRUNCATE  TABLE 表名;

【MySql】SQL语句DDL类相关推荐

  1. 数据库Mysql——sql语句大全

    注意:练习sql语句之前推荐先安装可视化软件如:SQLyog.Navicat 15 for MySQL 不然就在cmd小黑窗口敲命令练习. 一篇掌握Mysql--sql语句 #注意:sql语句不区分大 ...

  2. 导出mysql sql语句吗_mysql sql语句导入与导出

    mysql sql语句导入与导出 导入: mysql -u root -p 数据库名 如: C:/mysql/bin>mysql -u root -p house < c:/1-1.txt ...

  3. MySQL sql语句获取当前日期|时间|时间戳

    文章转载于:博客园--水狼一族 文章地址:<MySQL sql语句获取当前日期|时间|时间戳> 一.基础时间函数 1.1 获得当前日期+时间(date + time)函数:now() My ...

  4. mysql sql语句生成日历表

    转载:http://blog.csdn.net/u010363836/article/details/52788358 mysql sql语句生成日历点击打开链接表  (主要用于按月,按天group ...

  5. Mysql SQL语句执行更新或者插入添加条件判断

    Mysql SQL语句执行更新或者插入添加条件判断 – 更新操作 – INSERT INTO materials (ID,Name,Remaining,Total) VALUES (1,'SolidW ...

  6. mysql sql语句执行顺序

    mysql sql语句执行顺序 引言:作为一个程序猿.要想优化sql,首先要明白sql语句的执行顺序.同时防止该死的面试官问一些数据库专业的问题有必要知道这些 sql语句select语句查询顺序 (7 ...

  7. mysql sql 语句事务_MySQL: 3、SQL语言 ②约束、事务

    一.SQL 约束 1.约束的作用: 对表中的数据进行进一步的限制,从而保证数据的正确性.有效性.完整性.违反约束的不正确数据将无法插入到表中 2.常见的约束: 3.主键约束: -- 特点: 不可重复. ...

  8. mysql sql语句大全

    1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份 ...

  9. mysql sql语句 入门_mysql(3)mysql的sql语句入门

    1.登录mysql与退出mysql 登录:mysql  -u账号 -p密码 -h主机地址 -P端口号  -e 执行的sql语句: //密码一般不直接写出,回车后隐藏写入 ,-h可以不写默认是local ...

最新文章

  1. linux 编辑hosts 命令,linux下修改hostid
  2. 深度残差网络 - Deep Residual Learning for Image Recognition
  3. centos7arm进入图形化_CentOS 7 安装图形化界面
  4. 账单比较java代码_Java代码比较两个文件的MD5
  5. python显示表格_在Python中获取Excel表格的数量
  6. (转)如何压缩SQL Server 2005指定数据库文件和日志的大小?
  7. 【安全】LDAP是轻量目录访问协议,英文全称是Lightweight Directory Access Protocol
  8. php 未实例化类调用方法的问题
  9. 局域网中搜计算机无法访问,怎么找不到共享电脑,手把手教你局域网中共享电脑找不到怎么办...
  10. shell编程cp强制覆盖拷贝时仍需确认问题的处理方法
  11. SQL2008 行锁使用RowLock
  12. mysql设计一个网上购物系统_网上购物系统的设计与实现(MyEclipse,MySQL)
  13. 英雄无敌服务器维护,3月18日 维护更新公告
  14. Scratch编程训练——小猫进圈
  15. 一、时间序列(1)资产收益率、随机过程、白噪声序列定义
  16. 南京大学计算机技术考研,南京大学计算机技术考研
  17. POI删除空白行 代码和其他用法(将会持续更新)
  18. Unity ipad UI适配
  19. 狂热分子——码头工人的哲学沉思录
  20. ES新特性之Reflect对象

热门文章

  1. P4 可编程网络 — 数据面转发技术发展史
  2. 高效程序员秘籍(6):使用CLCL加快写代码的速度
  3. 新版Q绑查询HTML源码
  4. 单模/多模光纤能和单模/多模光模块混用吗?
  5. pygame安装(参考:烟雨平生cj)
  6. SpringCloudGateway爆漏洞,快看看你的服务中招没?
  7. 力扣 149. 直线上最多的点数
  8. rop检查_他山之石丨详解抗VEGF治疗在ROP诊疗中的应用
  9. linux 串口转网口工具,linux下串口调试工具/串口终端推荐: picocom(转)
  10. 多线程加速 Excel 画像素画