JavaWeb_MySQL_1.1基础

数据库的基本概念

  1. DataBase 简称:DB

  2. 前端:展示等等

    后端:连接点:连接数据库JDBC,后面可以用mybatis。连接前端:servlet,spring ,spring mvc控制视图跳转,传数据给前端

    数据库: 存数据,持久化。txt,excel。

  3. 数据库的特点:

  4. 持久化存储数据的(对于内存中变量)。查询速度快,管理方便(对于文件)。本质还文件系统,以文件的形式保存在服务器上。

  5. 方便存储和管理数据

  6. 所有的关系型数据库都可以使用通用的SQL语句管理。DBMS database management system。

  7. 什么是SQL?
    Structured Query Language:结构化查询语言
    定义了操作所有关系型数据库的规则。每一种数据库操作的方式存在不一样的地方。

  8. 常见的数据库

    关系型数据库 SQL

    MySQL(小型数据库,开源免费)、Oracle(收费的大型数据库)、Sql Server(微软收费中型数据库,C#、.net常用)、DB2(IBM收费数据库,银行常用)、SQLite(嵌入式小型数据库,用于Android)

    通过表和表之间,行和列之间的关系进行数据的存储。

    非关系型数据库 NoSQL

    Redis、MongDB

    通过对象自身属性来决定。

DBMS(数据库管理系统DataBase Management System)

MySQL是RDBMS(relational数据库管理系统)


MySQL

SQL 作用

  1. 是一种所有关系型数据库的查询规范,不同的数据库都支持。
  2. 不同的数据库 SQL 语句有一些区别。

SQL通用语法

SQL 语句可以单行或多行书写,以分号结尾。
可使用空格和缩进来增强语句的可读性。
MySQL 数据库的 SQL 语句不区分大小写,关键字建议使用大写。

3 种注释
  • 单行注释: – 注释内容 或 # 注释内容
  • 多行注释: /* 注释 */

SQL语言分类

1)DDL(Data Definition Language)数据定义语言
用来定义数据库对象:数据库,表,列等。关键字:create, drop,alter,trancate 等
2)DML(Data Manipulation Language)数据操作语言
用来对数据库中表的数据进行增删改。关键字:insert,delete,update 等
3)DQL(Data Query Language)数据查询语言
用来查询数据库中表的记录(数据)。关键字:select, where 等
4)DCL(Data Control Language)数据控制语言(了解)
用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE 等
5)事务控制语言,包括提交事务,回滚事务等操作。commit、rollback、savepoint等
6)函数

表是一种数据库对象,是存储数据最基本的单元,每一个表必须要有表名,表名不能重复

命令行指令

mysql -uroot -ppassword

net start mysql , net stop mysqlmysql服务

FLUSH privileges;刷新权限

select user();

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY'MyPass@123';

netstat -ano查看端口状态

退出:exit; quit;

MySQL登录
  1. mysql -uroot -p密码
  2. mysql -hip -uroot -p连接目标的密码
  3. mysql --host=ip --user=root --password=连接目标的密码
数据库操作
查看数据库: show databases;
查看数据库字符集:show create database 数据库名字;
创建数据库:  
  create database db1 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;        # utf8编码
  create database db1 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;    # gbk编码

先判断是否存在:create database if not exit db1
使用数据库:use db1;
创建用户
    create user '用户名'@'IP地址' identified by '密码';
删除用户
    drop user '用户名'@'IP地址';
修改用户
    rename user '用户名'@'IP地址'; to '新用户名'@'IP地址';;
修改密码
    set password for '用户名'@'IP地址' = Password('新密码')
查看权限
show grants for '用户'@'IP地址' 
授权
grant 权限 on 数据库.表 to '用户'@'IP地址'
取消授权
revoke 权限 on 数据库.表 from '用户'@'IP地址'
show tables;                    # 查看数据库全部表
select * from 表名;             # 查看表所有内容
创建表:
create table 表名(
    列名  类型  是否可以为空,
    列名  类型  是否可以为空
)ENGINE=InnoDB DEFAULT CHARSET=utf8
删除表:
drop table 表名
清空表内容:
delete from 表名
truncate table 表名

DELETE:语句执行删除的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志中保存以便进行进行回滚操作。不改变空间。

TRUNCATE TABLE: 则一次性地从表中删除所有的数据并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。


数据库的列类型

  1. int:整数类型(常用) 4字节

    age int

    可以由十六进制表示:0x

    其他整数:tinyint、smallint、mediumint、bigint

  2. double:小数类型(长度,精度)8字节

    score double(5,2)

    其他浮点:float

  3. decimal:字符串形式的浮点数,金融计算使用。避免精度问题。

  4. datetime:日期,包含年月日时分秒,还有date,time。

    yyyy-MM-dd HH:mm:ss

    其他时间:date:只包含年月日、time: 只包含Hms

    . timestamp:时间戳类型

    包含年月日时分秒 yyyy-MM-dd HH:mm:ss

    1970.1.1到现在的毫秒数

如果不给这个字段赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值

  1. varchar:可变长度字符串 0~65535

    name varchar(20) : 姓名最大20个字符

    zhangsan 8个字符 张三 2个字符

    所有的字符串值,都用双引号或单引号标注,例如’abc’或"abc"
    链接两个字符串不能用+,而要使用concat函数,例如concat(“a”,“b”) 这个函数返回的结果就是"ab"

    其他字符串:char、tinytext、text

  2. null

    没有值,未知

    不要使用null进行运算

  3. BLOB

    二进制数据类型,储存非字符和文本的数据,例如图像,音频,视频。


数据库的字段属性

Unsigned:
  • 无符号的整数
  • 该列不能为负数
zerofill:
  • 0填充的
  • 不足的位数使用0来填充,int(3) — 5 — 005
自增:auto_increment
  • 自动在上一条基础上(默认)加1。

  • 通常用来标记唯一主键index,必须是整型。

  • 可以设定主键自增的起始值和步长。

    ALTER TABLE 列名称 AUTO_INCREMENT = 起始值;

非空 not null:
  • 非空字段,设置为not null不赋值就会报错,设置为null不赋值就是null。
默认:
  • 设置默认的值。
项目规范,必须要这五个字段:
/*	id 主键
    `version`	乐观锁
    is_delet	伪删除
    gmt_create	创建时间
    gmt_update	修改时间 */

DDL:操作数据库、表

操作数据库:CRUD

C(Create):创建
  1. 创建数据库:

     create database 数据库名称;
    
  2. 创建数据库,判断不存在,再创建:

     create database if not exists 数据库名称;
    
  3. 创建数据库,并指定字符集

     create database 数据库名称 character set 字符集名;
    

示例:创建db4数据库,判断是否存在,并制定字符集为gbk

create database if not exists db4 character set gbk;

R(Retrieve):查询
  1. 查询所有数据库的名称:

     show databases;
    
  2. 查询某个数据库的字符集:查询某个数据库的创建语句

     show create database 数据库名称;
    
U(Update):修改
  1. 修改数据库的字符集

     alter database 数据库名称 character set 字符集名称;
    
D(Delete):删除
  1. 删除数据库
    drop database 数据库名称;
  2. 判断数据库存在,存在再删除
    drop database if exists 数据库名称;
使用数据库
  1. 查询当前正在使用的数据库名称
    select database();
  2. 使用数据库
    use 数据库名称;

操作表

C(Create):创建
-- 创建表
create table 表名(
    '列名1' 数据类型1 字段,
    '列名2' 数据类型2 字段,
    ....
    '列名n' 数据类型n 字段
);
create table student(
    -- 指定自增
    id int auto_increment,
    name varchar(32),
    -- 设定初始值
    age int default 0,
    -- 指定不可为空,默认可以为空
    height float(3,2) not null
    score double(4,1),
    birthday date,
    insert_time timestamp-- 设定为主键,这里不设置会报错,因为自增的一定是主键。
    constraint student primary key(id)
);

最后一列,不需要加逗号,末尾分号。

复制表:create table 表名 like 被复制的表名;

R(Retrieve):查询
  • 查询某个数据库中所有的表名称
    • show tables;
  • 查询表结构
    • desc 表名;
U(Update):修改
  1. 修改表名
    alter table 表名 rename to 新的表名;
  2. 修改表的字符集
    alter table 表名 character set 字符集名称;
  3. 添加一列
    alter table 表名 add 列名 数据类型;
  4. 修改列名称 类型
    alter table 表名 change 列名 新列名 新数据类型;
    alter table 表名 modify 列名 新数据类型;
  5. 删除列
    alter table 表名 drop 列名;
-- add后面写定义字段的格式
alter table student add weight float(4,1)

-- 也可以为已创建的表添加约束
alter table student add constraint unique_sno unique(sno)

-- student表中体重 的类型改成 float(5,2)
alter table student change weight weight float(5,2)
alter table student modify weight float(5,2)
-- student表中 weight 名字改成 wh
alter table student change weight wh float(5,2)

-- 修改student表 名字
alter table student rename to students
D(Delete):删除

drop table 表名;

drop table if exists 表名;


DML:增删改表中数据

添加数据

insert into 表名(列名1,列名2,...列名n) values(值1,值2,...值n);

  1. 列名和值要一一对应。
  2. 如果表名后,不定义列名,则给所有列添加值
    insert into 表名 values(值1,值2,...值n);
  3. 除了数字类型,其他类型需要使用引号(单双都可以)引起来
-- 可以一次插入多行记录
insert into student
values (22030108,'rose3',20,1.82,'1994-06-27'),
(22030109,'rose4',20,1.82,'1994-06-27'),
(22030110,'rose5',20,1.82,'1994-06-27')

删除数据:

delete from 表名 [where 条件]

如果不加条件,则删除表中所有记录。

如果要删除所有记录
  1. delete from 表名;

    不推荐使用。有多少条记录就会执行多少次删除操作

  2. TRUNCATE TABLE 表名;

    推荐使用,效率更高,先删除表,然后再创建一张一样的表。

修改数据:

update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];

如果不加任何条件,则会将表中所有记录全部修改。


DQL:查询表中的记录

select 字段 from 表名;
实际使用中严格意义上要避免使用select *

select 字段列表	from 表名列表	 where 条件列表	 group by 分组字段	 having 分组之后的条件
order by 排序	limit 分页限定

基础查询

  1. 多个字段的查询
    select 字段名1,字段名2… from 表名;

如果查询所有字段,则可以使用*来替代字段列表。
在查询时尽量不使用 * ,查询速度慢

  1. 去除重复:distinct

    -- 查询员工表中 所有的部门
    select distinct department_id from employee
    
  2. 计算列

    一般可以使用四则运算计算一些列的值。(一般只会进行数值型的计算)

    ifnull(表达式1,表达式2):null参与的运算,计算结果都为null

    表达式1:哪个字段需要判断是否为null;
    表达式2:如果该字段为null后的替换值。

    -- 查询员工姓名 和 年收入
    select first_name,salary*12+salary*ifnull(commission_pct,0) from employee
    

    concat 拼接字符串

    -- 查询员工姓名全名 first_name和last_name 相连的结果
    select concat(first_name,last_name) from employee
    
  3. 起别名:

    as:as也可以省略

条件查询

select ... from 表名 [where boolean表达式]

sql运算符
  1. 、< 、<= 、>= 、= 、<>

  2. BETWEEN…AND… – 两边都可以取到, 也可以用 >= and <= 代替

  3. IN( 集合)

  4. LIKE:模糊查询

  5. 占位符配合LIKE:

    • _:单个任意字符
    • %:多个任意字符
  6. IS NULL , IS NOT NULL

  7. and 或 &&

  8. or 或 ||

  9. not 或 !

  10. LEFT(str,len)

  11. RIGHT(str,len)

  12. SUBSTR(str FROM pos FOR len)

案例
-- 查询年龄大于20岁
SELECT * FROM student WHERE age > 20;
SELECT * FROM student WHERE age >= 20;

-- 查询年龄等于20岁
SELECT * FROM student WHERE age = 20;

-- 查询年龄不等于20岁
SELECT * FROM student WHERE age != 20;
SELECT * FROM student WHERE age <> 20;

-- 查询年龄大于等于20 小于等于30
SELECT * FROM student WHERE age >= 20 &&  age <=30;
SELECT * FROM student WHERE age >= 20 AND  age <=30;
SELECT * FROM student WHERE age BETWEEN 20 AND 30;

-- 查询年龄22岁,18岁,25岁的信息
SELECT * FROM student WHERE age = 22 OR age = 18 OR age = 25
SELECT * FROM student WHERE age IN (22,18,25);

-- 查询英语成绩为null
SELECT * FROM student WHERE english = NULL; 

-- 不对的。null值不能使用 = (!=) 判断
SELECT * FROM student WHERE english IS NULL;

-- 查询英语成绩不为null
SELECT * FROM student WHERE english  IS NOT NULL;

-- 查询姓马的有哪些? like
SELECT * FROM student WHERE NAME LIKE '马%';

-- 查询姓名第二个字不是化的人
SELECT * FROM student WHERE NAME NOT LIKE "_化%";

-- 查询姓名是3个字的人
SELECT * FROM student WHERE NAME LIKE '___';	

-- 查询姓名中包含德的人
SELECT * FROM student WHERE NAME LIKE '%德%';

-- 查询出名字开头字母相同的学生有多少人
SELECT LEFT(NAME,1),COUNT(0) FROM student GROUP BY LEFT(NAME,1)

= 在SQL中是比较运算符 不是赋值运算符 ; != 也可以写成<>


排序查询

order by 排序字段1 排序方式1 , 排序字段2 排序方式2... 写在最后面

排序方式:

  • ASC:升序,默认的。
  • DESC:降序。

如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。

order by 可以使用别名; where语句中不可以使用,只能使用表的列名

聚合函数:将一列数据作为一个整体,进行纵向的计算。

  1. count:统计个数
  2. 一般选择非空的列:主键
  3. count(*):所有只要有非空字段就算一条
  4. count(0):统计表中所有字段
  5. max:计算最大值
  6. min:计算最小值
  7. sum:计算和
  8. avg:计算平均值

注意:聚合函数的计算,排除null值。

  1. 选择不包含非空的列进行计算
  2. IFNULL函数

分组查询:

group by 分组字段 having 分组条件限定

  1. 分组之后查询的字段:分组字段、聚合函数

  2. where 和 having 的区别?

    where 在分组之前进行限定,如果不满足条件,则不参与分组。having在分组之后进行限定,如果不满足结果,则不会被查询出来,也就是说having的内容一定是聚合函数或者是group by中提到的字段

    where 后不可以跟聚合函数,having可以进行聚合函数的判断。

select中和分组函数一起查询的字段,应该在group by语句中

-- 按照性别分组。分别查询男、女同学的平均分
SELECT sex , AVG(math) FROM student GROUP BY sex;

-- 按照性别分组。分别查询男、女同学的平均分,人数
SELECT sex , AVG(math),COUNT(id) FROM student GROUP BY sex;

--  按照性别分组。分别查询男、女同学的平均分,人数 要求:分数低于70分的人,不参与分组
SELECT sex , AVG(math),COUNT(id) FROM student WHERE math > 70 GROUP BY sex;

--  按照性别分组。分别查询男、女同学的平均分,人数 要求:分数低于70分的人,不参与分组,分组之后。人数要大于2个人
SELECT sex , AVG(math),COUNT(id) FROM student WHERE math > 70 GROUP BY sex HAVING COUNT(id) > 2;
SELECT sex , AVG(math),COUNT(id) 人数 FROM student WHERE math > 70 GROUP BY sex HAVING 人数 > 2;

分页查询

limit 开始的索引,每页查询的条数;

公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数

-- 每页显示3条记录 
SELECT * FROM student LIMIT 0,3; -- 第1页
SELECT * FROM student LIMIT 3,3; -- 第2页
SELECT * FROM student LIMIT 6,3; -- 第3页

limit 是一个MySQL"方言"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值