MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

时间:2023-03-09 17:38:04
MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

1.SQL对数据库进行操作:

创建数据库:

语法: create database 数据库名称 [character set 字符集 collate 字符集校对规则];字符集校对规则即所用字符集的数据库中的数据值是否区分大小写、排列顺序等规则。

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

查看数据库:

查看数据库服务器中所有的数据库:show databases;

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

查看某个数据库的定义信息:show create database 数据库名称;

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

修改数据库:

语法:alter database 数据库名称 character set 字符集 collate 校对规则;

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

删除数据库:

语法名称:drop database 数据库名称;

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

切换数据库

语法: use 数据库名称;

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

查看当前正在使用的数据库

语法:select database();

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

2.对数据库的表进行操作

SQL创建表:

语法:create table 表的名称(字段的名称 字段类型(长度)约束,字段的名称 字段类型(长度)约束);  

字段的类型(一个实体对应一个表,一个实体的属性对应一个表的字段。)

  java中的类型    MySQL中的类型

  byte/short/int/long  tinyint/smallint/int/bigint

  float        float

  double       double

  boolean       bit

  char/String     char和varchar

  Date        date/time/datetime/timestamp

日期/时间/日期和时间/日期和时间

  File        BLOB/TEXT (BLOB二进制类型的文件,TEXT是文本类型的文件)

char和varchar的区别:char代表的是固定长度的字符或字符串,如char(8),向这个字段存入hello,数据库会使用三个空格将其补全,像hello world这种超过会报错。varchar代表可变长度的字符串,如varchar(8),存入hello,存入到数据库的就是hello。

datatime与timestamp的区别:datatime就是既有日期又有时间的日期类型,如果没有向这个字段中存值,数据库使用null存入到数据库中。timestamp也是既有日期又有时间的日期类型,如果没有向这个字段中存值,数据库会使用当前的系统时间存入到数据库中。

约束(约束的作用:保证数据的完整性)

单表约束的分类:

主键约束:(用于唯一地标识表中的每一条记录,可以定义一列或多列为主键。)primary key(主键约束默认就是唯一非空的)

唯一约束:(该字段值不可重复 )unique

非空约束:(可以重复,但不可以为空)not null

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

auto_increment是自动增加。

SQL查看表

查看某个数据库下所有的表

语法:show tables

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

查看某个表的结构信息

语法:desc 表名;

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

删除表:

语法:drop table 表名;

MySQL基础学习——SQL对数据库进行操作、对数据库的表进行操作

修改表:

添加列:alter table 表名 add 列名 类型(长度) 约束;

修改列的类型,长度和约束:alter table 表名 modify 列名 类型(长度) 约束;

删除列:alter table 表名 drop  列名;

修改列名称:alter table 表名 change 旧列名 新列名 类型(长度) 约束;

修改表名:rename table 表名 to 新的表名;

修改表的字符集:alter table 表名 character set 字符集;