黑马MySQL学习笔记
一.基础
1.MySQL概述
1.1数据库相关概念
数据库相关概念
-
主流的关系型数据库管理系统
-
关系型数据库(RDBMS)
概念: 建立在关系模型基础上,由多张相互连接的二维表组成的数据库.
特点:- 使用表存储数据,格式统一,便于维护
- 使用SQL语言操作,标准统一,使用方便
-
数据模型
1.2MySQL数据库
-
版本
MySQL官方提供了两种不同的版本:- 社区版(MySQL Community Server)
免费,MySQL不提供任何技术支持 - 商业版(MySQL Enterprise Edition)
收费,可以试用30天,官方提供技术支持
- 社区版(MySQL Community Server)
-
下载
下载地址link
- 安装
- 启动与停止
- 启动
net start mysql80 - 停止
net stop mysql80
- 启动
注:mysql80替换为自己的"Windows Service Name",本机为mysql
-
客户端连接
方式一:MySQL提供的客户端命令行工具
方式二:系统自带的命令行工具执行指令
mysql[-h 127.0.0.1][-P 3306]-u root -p
注意:使用这种方式时,需要配置PATH环境变量
2.SQL
2.1 SQL通用语法
- SQL通用语法
- SQL语句可以单行或多行书写,以分号结尾.
- SQL语句可以使用空格/缩进来增强语句的可读性.
- MySQL数据库的SQL语句不区分大小写,关键字建议使用大写.
- 注释:
- 单行注释:- -注释内容或 #注释内容(MySQL特有)
- 多行注释: /* 注释内容 */
2.2 SQL分类
- SQL分类
2.3 DDL
-
DDL-数据库操作
- 查询
查询所有数据库:
SHOW DATABASES;
查询当前数据库
SELECT DATABASE();
- 创建
CREATE DATABASE [IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集] [COLLATE 排序规则];
- 删除
DROP DATABASE [IF EXISTS] 数据库名;
- 使用
USE 数据库名;
- 查询
-
DDL-表操作-查询
- 查询当前数据库所有表
SHOW TABLES;
- 查询表结构
DESC 表名
- 查询指定表的建表语句
SHOW CREATE TABLE 表名
- 查询当前数据库所有表
-
DDL-表操作-创建
-
DDL-表操作-数据类型
MySQL中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型.
案例
-
DDL-表操作-修改
-
添加字段
ALTER TABLE 表名 ADD字段名 类型(长度) [COMMENT注释] [约束];
案例:
为emp表增加一个新的字段"昵称"为nickname,类型为varchar(20)
ALTER TABLE emp ADD nickname varchar(20) COMMENT '昵称' ;
-
修改数据类型
ALTER TABLE 表名 MODIFY 字段名 新数据类型(长度);
-
修改字段名和字段类型
ALTER TABLE 表名 CHANGE 旧字段名 新字段名类型(长度) [COMMENT 注释] [约束];
案例:
将emp表的nickname字段修改为username,类型为varchar(30)
ALTER TABLE emp CHANGE nickname username varchar(30) COMMENT'昵称' ;
-
删除字段
ALTER TABLE 表名 DROP 字段名;
案例:
将emp表的字段username删除
ALTER TABLE emp DROP username;
-
修改表名
ALTER TABLE 表名 RENAME TO 新表名;
案例:
将emp表的表名修改为employee
ALTER TABLE emp RENAME TO employee;
-
-
DDL-表操作-删除
- 删除表
DROP TABLE [IF EXISTS] 表名;
删除指定表,并重新创建该表
TRUNCATE TABLE表名;
(两种都删除所有数据,但是第二种重建空表)
- 删除表