MySQL 学习笔记

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL 学习笔记 mysql数据库的内部存储结构 数据库操作语句 1.查看所有数据库 1、查询mysql服务软件的所有数据仓库 show databases; 2、查看mysql数据仓库的编码 show create database mysql; 1 2 3 nformation_schema数据库:  其中保存着关于MySQL服务器所维护的所有其他数据库的信息。

MySQL 学习笔记

mysql数据库的内部存储结构

这里写图片描述

数据库操作语句

1.查看所有数据库

1、查询mysql服务软件的所有数据仓库     show databases;
2、查看mysql数据仓库的编码            show create database mysql;


  
  • 1
  • 2
  • 3

nformation_schema数据库: 
其中保存着关于MySQL服务器所维护的所有其他数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权限等。 
performance_schema 数据库: 
存储引擎:命名PERFORMANCE_SCHEMA ,主要用于收集数据库服务器性能参数。 
mysql 数据库: 
mysql库是系统库,里面保存有账户信息,权限信息,存储过程,event,时区等信息。 
test 数据库: 
这个是安装时候创建的一个测试数据库,和它的名字一样,是一个完全的空数据库,没有任何表,可以删除。

2.创建数据库

1、创建一个名称为mydb1的数据库。             create database mydb1;
2、创建一个使用utf8字符集的mydb2数据库。       create database mydb2 character set utf8;


  
  • 1
  • 2
  • 3

3.删除数据库

需求:删除前面创建的mydb1数据库          drop database mydb1;

  
  • 1

4.修改数据库编码集

需求:修改mydb2字符集为gbk               alter database mydb2 character set gbk;

  
  • 1

5.切换数据库和查看正在使用的数据库

需求1:查看正在使用的数据库              select database();
需求2: 切换数据库                      use mydb2;


  
  • 1
  • 2
  • 3

6.数据表结构的sql语句

【示例】 
需求:创建一个员工表,员工表有工号、姓名、年龄、性别、生日。

Java 代码编写 :

class Employee {
    private int id;
    private String name;
    private int age;
    private char gender;
    private Date birthday;
}


  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

MySql 创建数据表 : variable char 长度

create table employee (
    id int,
    name varchar(30),
    age int,
    gender varchar(10),
    birthday date
);


  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

7.查看表 :

需求1 查看该数据库的所有的表         show tables;
需求2: 查看建表语句以及字符集            show create table employee;
需求3: 查看表的列信息 (查看表结构)        desc emloyee;     description 描述


  
  • 1
  • 2
  • 3
  • 4

约束 : 
意义:保证数据的有效性和完整性。可以确保数据库满足业务规则。

【示例】 
需求:创建一个员工表,员工有工号、姓名、年龄、性别、生日和住址。 
1、要求工号是主键并且设置主键自增长 
2、姓名必须是唯一性的 
3、年龄必须是非空的 
4、地址必须是唯一的,并且非空。

create table emp (
    id int primary key auto_increment,
    name varchar(30) unique,
    age int not null,
    gender varchar(10),
    birthday date,
    address varchar(30) unique not null
);


  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

数据表结构的修改 
语法:alter table 表名 增/删/改 列名 类型(长度) 约束; add/modify/drop/change/rename

需求1:在emp表上增加salary列     alter table emp add salary int;

需求1:修改name列的长度为20       alter table emp modify name varchar(20) unique;
需求2:修改birthday列不能为null      alter table emp modify birthday date not null;

需求:修改列名name为username        alter table emp change name username varchar(20) unique;

需求:删除age列                   alter table emp drop age;

需求:将emp表名修改为emp2表       rename table emp to emp2;

需求7: 将employee的编码修改成utf8      alter table employee character set utf8;


  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

数据表的删除 
需求:删除employee表 drop table employee;

数据记录的增删改 
注意:我们需要再创建一张,建表语句如下:

create table user (
    id int primary key auto_increment,
    name varchar(20) unique,
    age int not null,
    gender varchar(10),
    birthday date,
    address varchar(50) unique not null
);


  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

查看表中数据的指令 : select * from user; 
insert 语句—-数据记录的增加

  1. insert into user(列1, 列2, 列3, 列4, 列5) values(值1, 值2, 值3, 值4, 值5); 所有列全部定义.
  2. insert into user(列1, 列2, 列3) values(值1, 值2, 值3); 部分列选择定义
  3. insert into user values(值1, 值2, 值3, 值4, 值5); 省略列名, 值需要全部提供.

select * from user; 查询表中的所有数据.

insert into user(id,name,age,gender,birthday,address) values(null,张三,18,male,1999-9-9,南京东路100号);

update 语句—-修改表记录 
格式 : update 表名 set 列名 = 值 [where 条件];

需求 : 将所有人的年龄修改为20岁。                 update user set age = 20;

需求 : 将姓名为张三的人的年龄改为18岁。      update user set age = 18 where name = ‘张三’;

需求 : 将姓名为李四的人的年龄改为30,地址改为航都路18号     update user set age = 30, address = ‘航都路18号’ where name = ‘李四’;

需求 : 将王五的年龄在原基础上增加2岁。       update user set age = age + 2 where name = 王五;



  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

delete语句—–删除表中数据的语句

格式 : delete from 表名 [where 条件];

需求 : 删除表中名称为’王五’的记录。        delete from user where name = 王五;

需求 : 删除年龄是30岁的员工。           delete from user where age = 30;

需求 : 删除表中所有记录。              delete from user;


  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

Truncate 语句—-删除数据 
删除表记录 : truncate table user; user表还在, 删除的是user中的所有数据.

直接将 user 表删除. 不是删除表中的行记录. 
然后新建了一张和 user 表一模一样的数据表.

说明1 : delete from 语句删除是逐行依次删除. (一条一条删除的), 主键记录依然存在. 
说明2 : truncate table 直接将表删除, 然后创建一张一模一样的数据表. 主键从头开始.

DCL 用户操作 : 
创建用户 : 
CREATE USER ‘用户名’@’主机名’ IDENTIFIED BY ‘密码’;

-- Jack 用户只能在localhost这个IP登录mysql服务器
CREATE USER 'Jack'@'localhost' IDENTIFIED BY '123';
-- Rose 用户可以在任何电脑上登录mysql服务器
CREATE USER 'Rose'@'%' IDENTIFIED BY '123';

  
  • 1
  • 2
  • 3
  • 4

授权用户 
GRANT 权限1, 权限2… ON 数据库名.表名 TO ‘用户名’@’主机名’;

给 Jack 用户分配对test这个数据库操作的权限
GRANT CREATE,ALTER,DROP,INSERT,UPDATE,DELETE,SELECT ON test.* TO 'Jack'@'localhost';

给 Rose 用户分配对所有 数据库操作的权限
CREATE USER 'Rose'@'%' IDENTIFIED BY '123';
GRANT ALL ON *.* TO 'Rose'@'%';


  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

查看权限 : 
SHOW GRANTS FOR ‘用户名’@’主机名’;


查看 Jack 用户的权限
SHOW GRANTS FOR 'Jack'@'localhost';


  
  • 1
  • 2
  • 3
  • 4

撤销权限 : 
REVOKE 权限1, 权限2… ON 数据库.表名 FROM ‘用户名’@’主机名’;

撤销 Jack 用户对test操作的权限
REVOKE ALL ON test.* FROM 'Jack'@'localhost';


  
  • 1
  • 2
  • 3

删除用户 : 
DROP USER ‘用户名’@’主机名’;

删除 Jack
DROP USER 'Jack'@'localhost';


  
  • 1
  • 2
  • 3

修改用户名密码 :

1.修改管理员密码 : 
mysqladmin -u root -p password 新密码 – 新密码不需要加上引号

mysqladmin -u root -p password 123456
输入老密码

  
  • 1
  • 2

2.修改普通用户密码 : 
set password for ‘用户名’@’主机名’ = password(‘新密码’);

set password for 'Rose'@'%' = password('666666');

  
  • 1

事务 transction

事务:就是将一组sql语句当作一个整体。要成功一起成功,要失败一起失败。

CREATE TABLE account (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(10),
    money DOUBLE
);

-- 添加数据
INSERT INTO account (name, money) VALUES ('Jack', 1000), ('Rose', 1000);


  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

假设在数据库中存在以上account表,记录了姓名和金钱,现在如果Jack要借1000元给Rose,应该如何操作?

这里写图片描述

我们需要进行的操作是把Jack的金额减去100,然后给Rose的金额加上一百:

update account set money = money -1000 where name = 'Jack'; 
update account set money = money -1000 where name = 'Rose'; 

  
  • 1
  • 2

这里写图片描述

这个看起来似乎是没有问题的,但是如果两条语句中有一条执行失败了呢?

update account set money = money -1000 where name = 'Jack'; 
update account set money = money +1000 where nmae = 'Rose';

  
  • 1
  • 2

这里写图片描述

这就尴尬了,钱我给了,你却没收到,怎么办?

这个时候事务的作用就体现出来了,依然是之前的数据:

这里写图片描述

在Dao窗口执行命令,然后分别在DOS窗口和SQLyog里面查看表格内容

start transaction;
update account set money = money -1000 where name = 'Jack'; 
update account set money = money -1000 where name = 'Rose'; 
select * from account;


  
  • 1
  • 2
  • 3
  • 4
  • 5

这里写图片描述


这里写图片描述


通过SQLyog查询我们发现,表中的数据并没有发生修改,所以我们开启事务之后,进行所有的命令虽然都执行了,但是结果却没有保存到数据库中,此时如果我们发现结果是我们想要的我们可以执行commit命令提交代码;

commit;

  
  • 1

刷新表格:

这里写图片描述

此时,结果才真正的保存到数据库中。 
如果命令执行后的结果不是我们想要的结果,可以执行rollback命令,这样就不会对数据库数据进行更改。 
再次将数据恢复到初始状态 
这里写图片描述 
执行以下代码

start transaction;
update account set money = money -1000 where name = 'Jack'; 
update account set money = money -1000 where nmee = 'Rose'; 
select * from account;


  
  • 1
  • 2
  • 3
  • 4
  • 5

这里写图片描述 
第三行语句出错,结果不想保存,怎么办?Rollback

rollback;

  
  • 1

这里写图片描述

这样,数据库数据就能恢复到开启事务之前的状态。

需要强调的是:一旦执行了commit命令或者rollback命令,事务都会关闭,再次使用需要重新开启。

MySQL 的事务操作 :

1. start transaction; 开始事务.
2. commit 提交事务. (数据库中数据进行了永久性修改)        全部成功.  
3. rollback 回滚事务.   失败. (数据回到了开启事务之前)
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
存储 关系型数据库 MySQL
Linux C/C++ 开发(学习笔记八):Mysql数据库图片存储
Linux C/C++ 开发(学习笔记八):Mysql数据库图片存储
153 0
|
3月前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
161 6
|
3月前
|
SQL 关系型数据库 MySQL
Mysql学习笔记(三):fetchone(), fetchmany(), fetchall()详细总结
MySQL中用于数据检索的`fetchone()`, `fetchmany()`, `fetchall()`函数的功能、SQL语句示例和应用场景。
104 3
Mysql学习笔记(三):fetchone(), fetchmany(), fetchall()详细总结
|
3月前
|
SQL Ubuntu 关系型数据库
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
本文为MySQL学习笔记,介绍了数据库的基本概念,包括行、列、主键等,并解释了C/S和B/S架构以及SQL语言的分类。接着,指导如何在Windows和Ubuntu系统上安装MySQL,并提供了启动、停止和重启服务的命令。文章还涵盖了Navicat的使用,包括安装、登录和新建表格等步骤。最后,介绍了MySQL中的数据类型和字段约束,如主键、外键、非空和唯一等。
85 3
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
|
3月前
|
关系型数据库 MySQL 数据库
Mysql学习笔记(四):Python与Mysql交互--实现增删改查
如何使用Python与MySQL数据库进行交互,实现增删改查等基本操作的教程。
78 1
|
7月前
|
SQL Oracle 关系型数据库
MySQL学习笔记
MySQL学习笔记
45 0
|
5月前
|
SQL druid Java
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)(下)
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)
70 3
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)(下)
|
5月前
|
SQL Java 关系型数据库
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)(上)
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)
227 3
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)(上)
|
5月前
|
SQL 关系型数据库 MySQL
Java数据库部分(MySQL+JDBC)(一、MySQL超详细学习笔记)(下)
Java数据库部分(MySQL+JDBC)(一、MySQL超详细学习笔记)
48 6
|
5月前
|
SQL 关系型数据库 MySQL
MySQL学习笔记
这篇文章是一份关于MySQL数据库操作的学习笔记,涵盖了数据库的终端操作、数据类型、建表约束、事务处理以及SQL的连接查询等基础知识点。