数据库学习笔记

342 阅读5分钟

跟着狂神学习Java,这是学到数据库的时候学习笔记,如有不足请指出!

一、关系型数据库

(一)初识 MySQL

1.1 为什么学习数据库

  1. 岗位需求
  2. 现在的世界,大数据时代,得数据库者得天下。
  3. 被迫需求:存数据
  4. 数据库是所有软件体系中最核心的存在 DBA

1.2 什么是数据库

数据库(DB, DataBase)

概念:数据仓库,软件, 安装在操作系统(windows, linux, mac, .....)之上,SQL,可以存储大量是的数据。500w!

作用:存储数据, 管理数据

1.3 数据库分类

关系型数据库:(SQL)

  • MySQL,Oracle,SQL Server, DB2, SQLlite
  • 通过表和表之间,行和行之间的关系进行数据的存储, 学员信息表,考勤表...

非关系型数据库:(NoSQL)

  • Redis, MongDB
  • 非关系型数据库,对象存储,通过对象自身的属性来决定。

DBMS(数据库管理系统)

  • 数据库的管理软件,科学有效的管理我们的数据,维护和获取数据
  • MySQL,数据管理系统!

image.png

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 配置文件 my.ini
[mysqlId]
# 目录一定要换成自己的
basedir=D:\Develop\mysql5.7\
datadir=D:\Develop\mysql5.7\data\
port=3306
skip-grant-tables # 跳过密码验证
  1. 启动管理员模式下的 cmd, 运行所有提示命令
  2. 安装 mysql 服务
  3. 初始化数据库文件
  4. 启动 mysql, 进去修改密码
  5. 进入 Mysql, 通过命令行(-p 后面不加空格),修改密码(sql语句后面一定要加分号!)
  6. 注释掉 ini 文件的最后一行跳过密码验证 skip-grant-tables
  7. 重启 MySQL,连接测试,如果连接成功就可以了!

image.png

可能遇到的问题

  1. 缺少组件 .dll
  2. 命令输错

sc delete mysql, 清空服务

1.6 安装SQLyog

  1. 安装
  2. 注册
  3. 打开连接数据库
  4. 新建数据库 school
  5. 新建一张表 student
字段: id, name,age
  1. 查看表
  2. 自己尝试添加多条记录

1.7 连接数据库

命令行连接!

mysql -u root -p 123456 -- 连接数据库

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;  -- 创建一个数据库
use westos;

exit   -- 退出连接

-- 单行注释(SQL原生注释)
/*
SQL的多行注释
*/

数据库 xxx 语言 --> CRUD 增删改查

DDL 定义

DML 操作

DQL 查询

DCL 控制

(二) 操作数据库

操作数据库 -- 操作数据库中的表 -- 操作数据库中的表的字段

MySQL关键字不区分大小写!

2.1 操作数据库(了解)

  1. 创建数据库
create database [if not exists] westos;
  1. 删除数据库
drop database if exists westos;
  1. 使用数据库
-- tab 键的上面
-- 如果表名或者字段名是一个特殊字符,就需要加上``
use `school`
  1. 查看数据库
show databases  -- 查看所有的数据库

学习思路:

  • 对照 SQLyog 可视化历史记录查看 sql
  • 固定的语法或关键字必须强行记住!

2.2 数据库的列类型

  • 数值
    • tinyint ------ 十分小的数据 -------- 1字节
    • smallint ----- 较小的数据 ---------- 2字节
    • mediumint - 中等大小的数据 ------3字节
    • int ---------- 标准的整数 ---------- 4字节
    • bigint ------- 较大的数据 ---------- 8字节
    • float ---------单精度浮点数 --------4字节
    • double ------ 双精度浮点数 -------- 8字节(精度问题!)
    • decimal ----- 字符串形式的浮点数,金融计算的时候,一般使用decimal
  • 字符串
    • char 字符串固定大小的 0~255
    • varchar 可变字符串 0~65535 常用的 String
    • 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

  • 假设设置为 not null, 如果不给赋值就会报错!
  • null, 如果不填写值,默认就是null

默认

  • 设置默认的值
  • sex, 默认值为 男, 如果不指定该列,

二、非关系型数据库