又是新的一年奋斗路的开启,相信有不少人农历新年之后,肯定会有所变动(跳槽加薪少不了)。所以,我把往期推送过的MySQL技术文章做了一个相关的整理,基础不好的可以从最基础的学习一遍,提高的也可以从中再提取深入一下。
码字不易,如有帮助,请随手 点在看 与 转发朋友圈 支持一下民工哥,关注我,一起学习更多的IT技术知识,共同进步。
数据库是什么
数据库管理系统,简称为DBMS(Database Management System),是用来存储数据的管理系统。
DBMS 的重要性
-
无法多人共享数据
-
无法提供操作大量数据所需的格式
-
实现读取自动化需要编程技术能力
-
无法应对突发事故
DBMS 的种类
-
层次性数据库
-
最古老的数据库之一,因为突出的缺点,所以很少使用了
-
-
关系型数据库
-
采用行列二维表结构来管理数据库,类似Excel的结构,使用专用的SQL语言对数据进行控制。
-
-
关系数据库管理系统的常见种类
-
Oracle ==> 甲骨文
-
SQL Servce ==> 微软
-
DB2 ==> IBM
-
PostgreSQL ==> 开源
-
MySQL ==> 开源
-
-
面向对象的数据库
-
XML数据库
-
键值存储系统
-
DB2
-
Redis
-
MongoDB
-
SQL 语句及其种类
-
DDL(数据定义语言)
-
create ==> 创建数据库或者表等对象
-
drop ==> 删除数据库或者表等对象
-
alter ==> 修改数据库或者表等对象的结构
-
-
DML(数据操作语言)
-
select ==> 查询表中数据
-
insert ==> 向表中插入数据
-
update ==> 更新表中数据
-
delete ==> 删除表中数据
-
-
DCL(数据控制语言)
-
commit ==> 决定对数据库中的数据进行变更
-
rollback ==> 取消对数据库中的数据进行变更
-
grant ==> 赋予用户操作权限
-
revoke ==> 取消用户的操作权限
-
SQL 的基本书写规则
-
SQL 语句要以;结尾
-
关键字不区分大小写,但是表中数据区分大小写
-
关键字大写
-
表名的首字母大写
-
列明等小写
-
常数的书写方式是固定的
-
遇到字符串、日期等类型需要用到''
-
单词间需要使用空格分割
-
命名规则
-
数据库和表的名称可以使用英文、数据以及下划线
-
名称必须以英文作为开头
-
名称不能重复
数据类型
-
integer
-
数字型,但是不能存放小数
-
-
char
-
定长字符串类型,指定最大长度,不足使用空格填充
-
-
varchar
-
可变长度字符串类型,指定最大长度,但是不足不填充
-
-
data
-
存储日期,年/月/日
-
以上内容是对通用数据库以及sql语句相关的知识点介绍,本文不做过多的赘述,本文主要针对关系型数据库:MySQL 来进行各方面的知识点总结。
MySQL 数据库简介
MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一。
MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
-
MySQL 是开源的,目前隶属于 Oracle 旗下产品。
-
MySQL 支持大型的数据库。可以处理拥有上千万条记录的大型数据库。
-
MySQL 使用标准的 SQL 数据语言形式。
-
MySQL 可以运行于多个系统上,并且支持多种语言。这些编程语言包括 C、C++、Python、Java、Perl、PHP、Eiffel、Ruby 和 Tcl 等。
-
MySQL 对PHP有很好的支持,PHP 是目前最流行的 Web 开发语言。
-
MySQL 支持大型数据库,支持 5000 万条记录的数据仓库,32 位系统表文件最大可支持 4GB,64 位系统支持最大的表文件为8TB。
-
MySQL 是可以定制的,采用了 GPL 协议,你可以修改源码来开发自己的 MySQL 系统。
在日常工作与学习中,无论是开发、运维、还是测试,对于数据库的学习是不可避免的,同时也是日常工作的必备技术之一。在互联网公司,开源产品线比较多,互联网企业所用的数据库占比较重的还是MySQL。
更多关于MySQL数据库的介绍,有兴趣的读者可以参考官方网站的文档和这篇文章: 可能是全网最好的MySQL重要知识点 ,关于MySQL架构的介绍可以参考: MySQL 架构总览->查询执行流程->SQL 解析顺序
MySQL 安装
MySQL 8正式版8.0.11已发布,官方表示MySQL8要比MySQL 5.7快2倍,还带来了大量的改进和更快的性能!到底谁最牛呢?请看: MySQL 5.7 vs 8.0,哪个性能更牛?
详细的安装步骤请参阅: CentOS 下 MySQL 8.0 安装部署,超详细! ,介绍几个 8.0 在关系数据库方面的主要新特性: MySQL 8.0 的 5 个新特性,太实用了!
MySQL基础入门操作
Windows服务
-- 启动MySQL net start mysql -- 创建Windows服务 sc create mysql binPath= mysqld_bin_path(注意:等号与值之间有空格)
连接与断开服务器
mysql -h 地址 -P 端口 -u 用户名 -p 密码 SHOW PROCESSLIST -- 显示哪些线程正在运行 SHOW VARIABLES -- 显示系统变量信息
数据库操作
-- 查看当前数据库 SELECT DATABASE(); -- 显示当前时间、用户名、数据库版本 SELECT now(), user(), version(); -- 创建库 CREATE DATABASE[ IF NOT EXISTS] 数据库名 数据库选项 数据库选项: CHARACTER SET charset_name COLLATE collation_name -- 查看已有库 SHOW DATABASES[ LIKE 'PATTERN'] -- 查看当前库信息 SHOW CREATE DATABASE 数据库名 -- 修改库的选项信息 ALTER DATABASE 库名 选项信息 -- 删除库 DROP DATABASE[ IF EXISTS] 数据库名 同时删除该数据库相关的目录及其目录内容
表的操作
-- 创建表 CREATE [TEMPORARY] TABLE[ IF NOT EXISTS] [库名.]表名 ( 表的结构定义 )[ 表选项] 每个字段必须有数据类型 最后一个字段后不能有逗号 TEMPORARY 临时表,会话结束时表自动消失 对于字段的定义: 字段名 数据类型 [NOT NULL | NULL] [DEFAULT default_value] [AUTO_INCREMENT] [UNIQUE [KEY] | [PRIMARY] KEY] [COMMENT 'string'] -- 表选项 -- 字符集 CHARSET = charset_name 如果表没有设定,则使用数据库字符集 -- 存储引擎 ENGINE = engine_name 表在管理数据时采用的不同的数据结构,结构不同会导致处理方式、提供的特性操作等不同 常见的引擎:InnoDB MyISAM Memory/Heap BDB Merge Example CSV MaxDB Archive 不同的引擎在保存表的结构和数据时采用不同的方式 MyISAM表文件含义:.frm表定义,.MYD表数据,.MYI表索引 InnoDB表文件含义:.frm表定义,表空间数据和日志文件 SHOW ENGINES -- 显示存储引擎的状态信息 SHOW ENGINE 引擎名 {LOGS|STATUS} -- 显示存储引擎的日志或状态信息 -- 自增起始数 AUTO_INCREMENT = 行数 -- 数据文件目录 DATA DIRECTORY = '目录' -- 索引文件目录 INDEX DIRECTORY = '目录' -- 表注释 COMMENT = 'string' -- 分区选项 PARTITION BY ... (详细见手册) -- 查看所有表 SHOW TABLES[ LIKE 'pattern'] SHOW TABLES FROM 表名 -- 查看表机构 SHOW CREATE TABLE 表名 (信息更详细) DESC 表名 / DESCRIBE 表名 / EXPLAIN 表名 / SHOW COLUMNS FROM 表名 [LIKE 'PATTERN'] SHOW TABLE STATUS [FROM db_name] [LIKE 'pattern'] -- 修改表 -- 修改表本身的选项 ALTER TABLE 表名 表的选项 eg: ALTER TABLE 表名 ENGINE=MYISAM; -- 对表进行重命名 RENAME TABLE 原表名 TO 新表名 RENAME TABLE 原表名 TO 库名.表名 (可将表移动到另一个数据库) -- RENAME可以交换两个表名 -- 修改表的字段机构(13.1.2.