1 - 数据库的常见概念
数据:Data
数据库:DataBase(DB) 在硬盘上以文件的形式存在
数据管理员:DataBase Administrator(DBA)
-
数据库管理系统:DataBase Management System(DBMS)
常见的有:MySQL Oracle DB2 Sybase SqlServer
DBMS负责执行sql语句 通过执行sql语句来操作DB中的数据
数据库系统:DataBase System(DBS)
MySQL:数据库
2 - SQL语言
1.DQL(数据查询语言):查询语句 凡是select语句都是DQL
2.DML(数据操作语言):insert delete update 对表当中的语句进行增删改
3.DDL(数据定义语言):creat drop alter 对表结构进行增删改
4.TCL(事务控制语言):commit 提交事务 rollback回滚事务 (T代表Transation)
5.DCL(数据控制语言) :grant 授权 revoke 撤销权限等
数据库存在的意义就是为了做持久化存储
3 - 数据库基本操作
3.1 - 连接数据库
语法:mysql -h 主机名/IP地址 -u 用户名 -p 密码 [数据库名]
-- 连接MySQL但是不指定使用的数据库
mysql -u root -p
-- 连接MySQL的同时指定要使用的数据库
mysql -u root -p 数据库名
-- 连接MySQL的时候指定主机名
mysql -h localhost -u root -p
-- 连接MySQL的时候指定IP地址
mysql -h 127.0.0.1 -u root -p
-- 一步完成数据库的连接
mysql -uroot -ptoor
3.2 - mysql基本操作
- 通常情况下命令都需要以分号结束
- 可以将一条命令在任意一个可以插入空格的位置拆分成多行,当遇到分号的时候结束当前的这条命令
- 可以通过
\c
来取消一条命令的执行 - 帮助信息查看:
\h
或help
或?
- 查看当前数据库服务器的状态
\s
- 将查询的结果纵向显示
\G
- 退出MySQL的方法:
exit
或quit
或\q
- ctrl+C强行终止
3.3 - 常用mysql命令
1.查看有哪些数据库
show databases (这个不是SQL语句 属于MySQL命令)换成Oracle就不能用了
注意每一个语句后面都要有分号!!!!!!
2.创建属于自己的数据库
create database 数据库名(这个不是SQL语句 属于MySQL命令)
3.使用自己创建的数据库
use ddgenius(这个不是SQL语句 属于MySQL命令)
4.查看当前数据库中有哪些表
show tables;
5.初始化数据
mysql > source + 文件路径(C:\Users\My\Desktop\资料汇总\F.java\java开发\MySQL数据库\bjpowernode.sql)
可以直接把文件拖过来(太大的命令记事本可能打不开)
6.删除数据库:drop database bjpowernode
4 - 数据表基本操作
4.1 - 介绍
数据表就是数据库中最基本的对象(Java 里就是用类对象来表示一个数据表的结构)单元
每一条数据记录:行
每个字段记录:列
-
设计表之前需要根据数据的对应实体和属性找到对应的关系(联系) - E-R图
- 实体:你想针对什么具体的事物来创建一个数据表
- 属性:该事物具备的属性,在数据表里面用字段来表示
EX:学生是实体,学号,姓名,性别,年龄,成绩...等等都是学生这个实体具备的属性(字段)
数据类型:数据表中的属性具备适当的数据类型,尽量避免数据的冗余(时优空优)
4.2 - 四大数据类型
1 - 数字
类型名 | 空间(字节) | 描述 |
---|---|---|
tinyint | 1 | 非常小的整数类型 |
smallint | 2 | 比较小的整数类型 |
mediumint | 3 | 中等大小的整数类型 |
int | 4 | 标准的整数类型 |
bigint | 8 | 大整数类型 |
float | 4 ~ 8 | 单精度浮点型 |
double | 8 | 双精度浮点型 |
decimal | 自定义 | 以字符串形式显示浮点数 |
整型后面的括号:表示的是显示的位数,并不是存储的位数,比如 int(3),表示的是以3个长度来显示一个整数,如果这个数据的实际位数大于了这个括号中的值,则会截取括号中指定的位数进行显示,超出部分不会显示在结果中
浮点型后面的小括号:float(6,2)表示的是以六位的数字显示一个数值,其中小数点后保留两位,显示位数当中小数点不算作一位,比如:1234.56 就符合以上的条件(浮点数中会四舍五入),存储也按照小括号里面的约束
2 - 字符串类型
类型名 | 空间(字节) | 描述 |
---|---|---|
char[(M)] | M | 不可变长字符串 |
varchar[(M)] | length + 1 | 可变长字符串 |
tinyblob / tinytext | length + 1 | 小二进制和文本串 |
blob / text | length + 2 | 小二进制和文本串 |
mediumblob / mediumtext | length + 3 | 中二进制和文本串 |
longblob / longtext | length + 4 | 大二进制和文本串 |
enum | 1 / 2 | 枚举 |
set | 1 / 2 / 3 / 4 / 8 | 集合 |
char和varchar怎么选择?
在实际的开发中,当某个字段中的数据长度不发生改变的时候,是定长的,例如:性别、生日等都是采用char。
当一个字段的数据长度不确定,例如:简介、姓名等都是采用varchar。(自动化分配空间,底层有if语句)
3 - 时间和日期
基本不用:时间戳代替
类型名 | 空间(字节) | 描述 |
---|---|---|
date | 3 | YYYY-MM-DD |
time | 3 | hh:mm:ss |
datetime | 8 | YYYY-MM-DD hh:mm:ss |
timestamp | 4 | YYYYMMDDhhmmss |
year | 1 | YYYY |
4 - NULL值
- NULL 不意味着没有值也不意味着未知值
- 在 MySQL 中可以检测到某一条数据的某一个字段值是否为 NULL
- 不能对 NULL 进行算术运算,对 NULL 进行算术运算得到的结果还是 NULL
- 在 MySQL 当中 0 和 NULL 都可以作为 false 的另外一种表现形式,其他的值都是 true
4.3 - 创建数据表
create table 表名(
字段名1 数据类型,
字段名2 数据类型,
字段名3 数据类型,
....
);
create table t_student(
no bigint,
name varchar(255),
sex char(1),
classno varchar(255),
birth char(10)
);
varchar是可变长!!必须给长度
可以使用default添加默认值
sex char(1) default 1,//默认值1
表的复制
create table 表名 as select语句;
将查询结果当做表创建出来。
4.4 - 删除数据表
drop table 数据表名
drop table if exists t_student; // 当这个表存在的话删除。
4.5 - 运算符
- AND 或 && 逻辑与
- OR 或者 || 逻辑或
- NOT 或者 ! 逻辑非
- XOR 或者 ^ 逻辑异或
- = 判断是否相等,相等为真
- <=> 是否相等,相等为真,可用于NULL(不推荐)
- != 或 <> 不等于为真,(<>不推荐)
- < > <= >= 基本的关系运算符
- is null 空为真
- is not null 非空为真
- between and 从哪儿到哪儿之间
- not between and 不在从哪儿到哪儿之间
- like 匹配字符串,匹配到结果为真(长得像什么一样)
- not like 匹配字符串,没有匹配到为真(张的不想什么一样)
- in 在集合中匹配,匹配到了为真