1. MySQL
javaee : 企业级java开发 web
前端(页面:渲染 展示 数据)
后台(连接点 : 连接数据库jdbc,链接前端(控制视图跳转,给前端传递数据))
数据库(存数据 : txt ,Word ,Excel )
只会写代码,学号数据库,基本混饭吃
操作系统,数据结构与算法!!!学会这些就很nice了
离散数学,数字电路,体系结构,编译原理----就很牛逼了已经+实战经验==高级程序员
1.1 为什么学习数据库
1.岗位需求
2.大数据时代`人人都会 得数据着得天下
3.被迫需求,存数据
4.数据可是所有软件的体系最核心的存在 DBA
1.2什么是数据库
数据库 (DB, DteBase)
概念 : 数据仓库,软件,安装在操作系统上面(Linux) SQL是一个操作系统语句,可以存储大量语句500w
作用:存数据,管理数据(类似于Excel)
1.3 数据库分类 DBSM(数据库管理系统)
**关系数据库:(SQL)
+ MySQL Oracle aqlserver
通过表和表之间,航和列直接的关系进行数据的存储,学员信息表
非关系型数据库:
Redis mongdb
== DBMS数据库管理系统 ==
- 数据库的管理软件,科学有效的管理数据
- MySQL 数据库管理
1.4MySQL
MySQL是一个关系型数据库管理系统
前世:瑞典MySQL AB公司
今生:属于Oracle旗下产品
MySQL是最好用的关系新数据库管理系统
中小型网站
安装MySQL
官网 : https://www.mysql.com/
安装MySQL
这里建议大家使用压缩版,安装快,方便.不复杂.
软件下载
mysql5.7 64位下载地址:
https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.19-winx64.zip
电脑是64位的就下载使用64位版本的!
安装步骤
1、下载后得到zip压缩包.
2、解压到自己想要安装到的目录,本人解压到的是D:\Environment\mysql-5.7.19
3、添加环境变量:我的电脑->属性->高级->环境变量
选择PATH,在其后面添加: 你的mysql 安装文件下面的bin文件夹
4、编辑 my.ini 文件 ,注意替换路径位置
[mysqld] basedir=D:\Program Files\mysql-5.7\ datadir=D:\Program Files\mysql-5.7\data\ port=3306 skip-grant-tables
5、启动管理员模式下的CMD,并将路径切换至mysql下的bin目录,然后输入mysqld –install (安装mysql)
6、再输入 mysqld --initialize-insecure --user=mysql 初始化数据文件
7、然后再次启动mysql 然后用命令 mysql –u root –p 进入mysql管理界面(密码可为空)
8、进入界面后更改root密码
update mysql.user set authentication_string=password(‘123456’) where user='root’and Host = ‘localhost’;
9、刷新权限
flush privileges;
10、修改 my.ini文件删除最后一句skip-grant-tables
11、重启mysql即可正常使用
net stop mysql net start mysql
12、连接上测试出现以下结果就安装好了
一步步去做 , 理论上是没有任何问题的 .
如果您以前装过,现在需要重装,一定要将环境清理干净 .
好了,到这里大家都装好了,因为刚接触,所以我们先不学习命令.
这里给大家推荐一个工具 : SQLyog .
即便有了可视化工具,可是基本的DOS命名大家还是要记住!
SQLyog
SQLyog下载
链接: https://pan.baidu.com/s/1D_iRna8V90omfHsKHyeBtg 提取码: bqht 复制这段内容后打开百度网盘手机App,操作更方便哦
可手动操作,管理MySQL数据库的软件工具
特点 : 简洁 , 易用 , 图形化
使用SQLyog管理工具自己完成以下操作 :
连接本地MySQL数据库
新建MySchool数据库
1.7 连接数据库
命令行连接
cd /dD:\MySQL\mysql-5.7.19\bin --连接数据库
mysql -uroot -p --进入数据库
update mysql.user set authentication_string =password('123456')where user='root' and Host = 'localhost';
flush privileges; ----刷新权限
-- ---------------------------------------------------------
-- 所有语句都是用;号结尾
show databases;-- 查看数据库
mysql> use school -- 切换数据库 use 数据库名
Database changed
--
show tables; -- 查看数据库中所有的表
describe student; -- 显示数据库中所有的表的信息
create database westos; -- 创建一个数据库
exit; --退出连接
/*注释*/
--
# 123
2 .操作数据库
操作数据库—>操作数据库中的表–>操作数据库中的表的数据
2.1操作数据库
-
创建数据库
CREATE DATABASE 数据库名; CREATE DATABASE IF NOT EXISTS 数据库名 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;-- 先会判断是否存在这个数据库名,后面是编码集为utf8,数据库排序规则是utf8_general_ci
-
删除数据库
DROP DATABASE [IF EXISTS] 数据库名;
-
使用数据库
USE `数据库名`
-
查看数据库
SHOW DATABASES -- 查看所有的数据库
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-44263p5O-1616596431643)(C:\Users\86155\AppData\Roaming\Typora\typora-user-images\1615816830046.png)]
思路:
-
对比:SQLyog可视化历史记录查看sql
-
固定的语法或者关键字必须记住
2.2数据库的数据类型
数值
-
tinyint 十分小的内存 一个字节
-
smallint 较小的数据 两个字节
-
int 标准的整数 四个字节 常用
-
mediumint 中等大小数据 三个字节
-
bigint 较大的数据 八个字节
-
float 单精度浮点 四个字节
-
double 双进度浮点 八个字节
-
decimal 字符串浮点数 金融计算的时候一般使用
字符串
- char 字符串固定大小 0-255
- varchar 可变字符串 0-65535 (16位2进制的数字)
- 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填充 int(3) ,5 — 005
自增
- 统常理解为自增,自动在上一条记录基础上+1
- 统常来设计唯一的逐渐`index,必须是整数类型
- 可以自定义设计主键自增的起始值和步长
非NULL not null
- x新建表格的时候如果给 “非空”(not null)打钩,如果不给他赋值就会报错
- null 如果不填写就是默认null
默认
- 设置默认的值!
- sex 默认为男 如果不指定就是默认值代替
数据字段属性
UnSigned
- 无符号的
- 声明该数据列不允许负数 .
ZEROFILL
- 0填充的
- 不足位数的用0来填充 , 如int(3),5则为005
Auto_InCrement
-
自动增长的 , 每添加一条数据 , 自动在上一个记录数上加 1(默认)
-
通常用于设置主键 , 且为整数类型
-
可定义起始值和步长
-
- 当前表设置步长(AUTO_INCREMENT=100) : 只影响当前表
- SET @@auto_increment_increment=5 ; 影响所有使用自增的表(全局)
NULL 和 NOT NULL
- 默认为NULL , 即没有插入该列的数值
- 如果设置为NOT NULL , 则该列必须有值
DEFAULT
- 默认的
- 用于设置默认值
- 例如,性别字段,默认为"男" , 否则为 “女” ; 若无指定该列的值 , 则默认值为"男"的值
`-- 目标 : 创建一个school数据库-- 创建学生表(列,字段)-- 学号int 登录密码varchar(20) 姓名,性别varchar(2),出生日期(datatime),家庭住址,email-- 创建表之前 , 一定要先选择数据库
CREATE TABLE IF NOT EXISTS `student` (
`id` int(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` varchar(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`pwd` varchar(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`sex` varchar(2) NOT NULL DEFAULT '男' COMMENT '性别',
`birthday` datetime DEFAULT NULL COMMENT '生日',
`address` varchar(100) DEFAULT NULL COMMENT '地址',
`email` varchar(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
-- 查看数据库的定义SHOW CREATE DATABASE school;-- 查看数据表的定义SHOW CREATE TABLE student;-- 显示表结构DESC student; -- 设置严格检查模式(不能容错了)SET sql_mode='STRICT_TRANS_TABLES';
数据表的类型
设置数据表的类型
CREATE TABLE 表名( -- 省略一些代码 -- Mysql注释 -- 1. # 单行注释 -- 2. /*...*/ 多行注释)ENGINE = MyISAM (or InnoDB)-- 查看mysql所支持的引擎类型 (表类型)SHOW ENGINES;
MySQL的数据表的类型 : MyISAM , InnoDB , HEAP , BOB , CSV等…
常见的 MyISAM 与 InnoDB 类型:
经验 ( 适用场合 ) :
- 适用 MyISAM : 节约空间及相应速度
- 适用 InnoDB : 安全性 , 事务处理及多用户操作数据表
数据表的存储位置
-
MySQL数据表以文件方式存放在磁盘中
-
- 包括表文件 , 数据文件 , 以及数据库的选项文件
- 位置 : Mysql安装目录\data\下存放数据表 . 目录名对应数据库名 , 该目录下文件名对应数据表 .
-
注意 :
-
-
* . frm – 表结构定义文件
-
* . MYD – 数据文件 ( data )
-
* . MYI – 索引文件 ( index )
-
InnoDB类型数据表只有一个 *.frm文件 , 以及上一级目录的ibdata1文件
-
MyISAM类型数据表对应三个文件 :
-
设置数据表字符集
我们可为数据库,数据表,数据列设定不同的字符集,设定方法 :
- 创建时通过命令来设置 , 如 : CREATE TABLE 表名()CHARSET = utf8;
- 如无设定 , 则根据MySQL数据库配置文件 my.ini 中的参数设定
修改数据库
修改表 ( ALTER TABLE )
修改表名 :ALTER TABLE 旧表名 RENAME AS 新表名
添加字段 : ALTER TABLE 表名 ADD字段名 列属性[属性]
修改字段 :
- ALTER TABLE 表名 MODIFY 字段名 列类型[属性]
- ALTER TABLE 表名 CHANGE 旧字段名 新字段名 列属性[属性]
删除字段 : ALTER TABLE 表名 DROP 字段名
删除数据表
语法:DROP TABLE [IF EXISTS] 表名
- IF EXISTS为可选 , 判断是否存在该数据表
- 如删除不存在的数据表会抛出错误
其他
1. 可用反引号(`)为标识符(库名、表名、字段名、索引、别名)包裹,以避免与关键字重名!中文也可以作为标识符!
2. 每个库目录存在一个保存当前数据库的选项文件db.opt
3. 注释: 单行注释 # 注释内容 多行注释 /* 注释内容 */ 单行注释 -- 注释内容 (标准SQL注释风格,要求双破折号后加一空格符(空格、TAB、换行等))
4. 模式通配符: _ 任意单个字符 % 任意多个字符,甚至包括零字符 单引号需要进行转义 \' 5. CMD命令行内的语句结束符可以为 ";", "\G", "\g",仅影响显示结果。其他地方还是用分号结束。delimiter 可修改当前对话的语句结束符。
6. SQL对大小写不敏感 (关键字)7. 清除已有语句:\c