数据库学习--DDL(数据库定义语言)

数据库

创建数据库

create database if not exists 库名;
说明:if not exists的存在为了保证数据库是唯一的,同时保证程序不阻塞

删除数据库

drop database if exists 库名;
说明: if exists 为保证程序不阻塞

查询表

show create table 表名;  =》展示创建表的时候的结构的详细信息
desc 表名; =》 展示基础的表信息

创建表

mysql 5.1版本以下 的不安装引擎,需自己安装
charset=utf8; 指定字符集
engine=innodb;指定引擎;
comment=“示例”;添加注释

create table if not exists Student(
	Sno varchar(9) primary key,
	Sname varchar(20) unique,
	Sage smallint,
	Ssex varchar(2),
	Sdept varchar(20)
)default charset=utf8 engine=InnoDB comment="示例1";

在每个字段后跟你想要设置的列特性

列特性的说明

  • not null:不为空
  • default:设置字段默认值
  • unique:唯一值,一列中只能出现一个
  • primary key:主键
  • auto_increment:自增键

修改表

向表中增加一列

alter table 表名 add 列名 特性;

修改表中数据类型

alter table 表名 modify column 列名 新类型;

删除表中列

alter table 表名 drop 列名;

修改列名或其他 【万能修改】

alter table 表名 change 旧列名 新列名 特性;

修改特性

主键

添加主键

alter table 表名 add primary key (列名)

删除主键

alter table 表名 drop primary key

索引

添加唯一值索引

alter table 表名 add unique(列名)

添加全文索引

alter table 表名 add fulltext(列名); 版本需要在5.7及以上

添加普通索引

alter table 表名 add index(列名)

删除索引

alter table 表名 drop index/unique/fulltext 列名;

修改索引

删除后再添加;不能直接修改

引擎

修改

alter table 表名 engine=引擎名;

显示所有引擎

show engines;

自增开始值的修改

alter table 表名 auto_increment=1;

删除表

drop table 表名;

数据类型

常用的数值,字符,事件

数值类型

类型大小无符号范围有符号范围
tinyint1字节-27,27-10,2^8 ^-1
smallint2字节-215,215-10,2^16 ^-1
mediumint3字节-223,223-10,2^24 ^-1
int/integer4字节-231,231-10,2^32 ^-1
bigint8字节-263,263-10,2^64 ^-1
float4字节-231,231-10,2^32 ^-1
double8字节-263,263-10,2^64 ^-1

unsigned :无符号,最小是0
zerofull:数值位数不足时,用0补齐

字符串

类型大小
char255字节 (定长)
varchar0-65535字节(弹性)
tintblob0-255字节(二进制)
tinttext0-255字节(文本)

日期

类型格式
dateyyyy-mm-dd
timehh:mm:ss
yearyyyy
datetimeyyyy-mm-dd hh:mm:ss
timestamp时间戳,毫秒数

类型为timestamp,默认插入数据的时间,更新时,时间也会变(版本>5.7)

  • 30
    点赞
  • 97
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值