MySQL
1、初始MySQL
JavaEE:企业级开发 web
前端(页面:展示,数据!)
后台(连接点:连接数据库JDBC,连接前端(控制,控制试图跳转,和给前端传递数据))
数据库(存数据,TXT,Excel,Word)
只会写代码,学好数据库,基本混饭吃;
操作系统,数据结构与算法,当一个不错的程序猿!
离散数学,数字电路,体系结构,编译原理,实战经验,优秀程序猿
1.1、为什么学习数据库
1、岗位需求
2、现在的世界,大数据时代~,得数据者得天下
3、被迫需求:存数据
4、数据库是所有软件体系中最核心的存在 DBA
1.2、什么是数据库
数据库(DB DataBase)
概念:数据仓库,软件,安装在操作系统(windows,linux,mac…)之上,SQL,可以存储大量数据。500万以内。
作用:存储数据,管理数据
1.3、数据库分类
关系型数据库:(SQL)
- MySQL、Oracle、SQL Server,DB2、SQLlite
- 通过表和表之间,行和列之间的关系进行数据的存储。学员表,考勤表…
非关系型数据库:(NoSQL)Not only SQL
- Redis,MongoDB
- 非关系型数据库,对象存储,通过对象的自身属性来决定。
DBMS(数据库管理系统)
- 数据库的管理软件,科学有效的管理我们的数据。维护和获取数据
- MySQL,数据库管理系统!
1.4、MySQL
MySQL是一个关系型数据库管理系统
前世:瑞典MySQL AB公司
今生:属于Oracle旗下产品
MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一
开源的数据库软件~
体积小,速度快,总体应用成本低,招人成本比较低,所有人必须会
中小型网站、或者大型网站,集群
5.7 稳
8.0 用的还不是很多
安装建议:
1、尽量不要使用exe,注册表
2、尽可能使用压缩包
1.5、安装MySQL
详细过程点这里
1.解压
2.把这个包放到自己的电脑环境目录下
3.配置环境变量
4.新建MySQL配置文件 ini结尾
1 | [mysqld] |
5.启动管理员模式下的cmd,运行所有的命令
6.安装MySQL服务
7.初始化数据库文件
8.启动MySQL,进去修改密码
9.进入MySQL通过命令行(-p后面不要加空格),修改密码(sql语句后面一定要加分号)
问题:
1、缺少组件 .dll
2、命令输出
1 | sc delete mysql |
1.6、安装SQLyog
1.无脑安装
2.注册
3.打开连接数据库
4.新建一个数据库 school
每一个sqlyog的执行操作,本质就是对应了一个sql,可以在软件的历史记录中查看
5.新建一张表 student
1 | 字段:id,name,age |
6.查看表
7.自己尝试添加多条记录
1.7、连接数据库
命令行连接
1 | mysql -u root -p123456 --连接数据库 |
数据库 xxx 语言 CRUD 增删改查! CV 程序猿 API程序猿 CRUD程序猿(业务)
DDL 定义
DML 操作
DQL 查询
DCL 控制
2、操作数据库 (了解)
操作数据库>操作数据库中的表>操作数据库中表的数据
MySQL语句不区分大小写
2.1、操作数据库
1、创建数据库
1 | CREATE DATABASE (IF NOT EXISTS) westos; |
2、删除数据库
1 | DROP DATABASE (IF EXISTS) hello; |
3、使用数据库
1 | --tab键的上面,如果你的表名或者字段名是一个特殊字符,就需要带 |
4、查看数据库
1 | SHOW DATABASES --查看所有的数据库 |
对比:sqlyog的可视化操作
2.2、数据库的列类型
数值
- tinyint 十分小的数据 1个字节
- smallint 较小的数据 2个字节
- mediumint 中等大小的数据 3个字节
- int 标准的整数 4个字节 常用的
- bigint 较大的数据 8个字节
- float 单精度浮点数 4个字节
- double 双精度浮点数 8个字节
- decimal 字符串形式的浮点数
金融计算的时候,一般使用
字符串
- char 字符串固定大小的 0-255
- varchar 可变字符串 0-65535
- tinytext 微型文本 2^8-1
- text 文本串 2^16-1
事件日期
java.util.Date
- date YYYY-MM-DD,日期
- time HH:mm:ss 时间格式
- datetime YYYY-MM-DD HH:mm:ss 最常用的时间格式
- timestamp 时间戳 1970.1.1到现在的毫秒数!也较为常用
- year 年份标识
null
- 没有值,未知
- 注意,不要使用null进行运算,结果为null
2.3、数据库的字段属性(重点)
Unsigned:
- 无符号的整数
- 声明了该列不能为负数
zerofill:
- 0填充的
- 不足的位数,使用0来填充,in(3),5,005
自增:
- 通常理解为自增,自动在上一条记录的基础上+1(默认)
- 通常用来设计唯一的住建~index,必须是整数类型
- 可以自定义设置主键自增的起始值和步长
非空:
NUll 和 not null
- 假设设置为not null,如果不给他赋值,就会报错
- NUll,如果不填写值,默认就是null
默认:
- 设置默认值
- sex,默认值为男,如果不指定该列的值,则会有默认的值!
扩展:目前看看就行
1 | /*每一个表都必须存在以下五个字段 |
2.4、创建数据库表
1 | -- 目标:创建一个school数据库 |
格式:
1 | create table[if not exists] `表名`( |
常用命令
1 | SHOW CREATE DATABASE school -- 查看创建数据库的语句 |
2.5、数据库表的类型
INNODB 默认使用
MYISAM 早些年使用
MYISAM | INNODN | |
---|---|---|
事务支持 | 不支持 | 支持 |
数据行锁定 | 不支持 | 支持 |
外键约束 | 不支持 | 支持 |
全文索引 | 支持 | 不支持 |
表空间大小 | 较小 | 较大,约为2倍 |
常规使用操作:
- MYISAM 节约空间,速度较快
- INNODB 安全性高,事务的处理,多表多用户操作
在物理空间存在的位置
所有的数据库文件都存在data目录下,一个文件夹就对应一个数据库
本质还是文件的存储
MySQL引擎在物理文件上的区别
-
INNODB在数据库表中只有一个*.frm文件,以及上级目录下的ipdata1文件
-
MYISAM对应文件
○*.frm 表结构定义文件 ○*.MYD 数据文件(data) ○*.MYI 索引文件(index)
设置数据库表的字符集编码
1 | charset=utf8 |
不设置的话,会是MySQL默认的字符集编码(不支持中文)
MySQL的默认编码是Latin1,不支持中文
在my.ini中配置默认的编码
1 | character-set-server=utf8 |
2.6、修改和删除
修改
删除