- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
MySQL快速入门,看这一篇就够了,库、表、数据相关操作都在这里👆
'''
不管BS还是CS架构,服务端和客户端都是基于socket通信来收发消息的,后台的编程语言有很多,数据类型可能不一样,那么在存储数据的时候使用数据库,SQL语句就规定了统一操作数据的语言
'''
关系型数据库特点
数据之间彼此有关系或者约束
存储数据的表现形式通常以表格存储,每个字段还会有存储类型的限制
MySQL:开源免费,比较好用
Oracle:收费,维护成本高,大型公司可能会用
PostgreSQL:支持二次开发
MariaDB:MySQL的替代产品(并且有自己的特性)
sqlite:小型数据库(django框架自带该数据库)
非关系型数据库特点:
存储数据通常以K,V键值对形式存储
约束不是很大,用于缓存等
redis:目前最火的缓存数据库 具有很多数据结构 功能强大
mongodb:文档型数据库 可以用在大数据和爬虫领域
memcache:已经被redis淘汰
类比理解
推荐下载5.6,5.7版本左右的,尽量不要下载最新版本
下载后解压缩
'''
打开bin文件
1. 服务端:mysqld.exe
2. 客户端:mysql.exe
'''
登录
# 在超级管理员身份下打开cmd命令窗口登录
mysql -uroot -h 127.0.0.1 -P 3306 -p
-u:用户
-h:地址
-P:端口
-p:密码
# 简写
mysql -uroot -p
# 只写mysql
mysql登录游客模式,不是管理员登录,只能体会lowb的功能
show databases; # 展示所有数据库
\c或 ctrl+c(新版本) # 取消执行
exit\ctrl+z(新版本) # 退出
win命令补充
# 查看进程
tasklist
tasklist |findstr mysqld
# 杀死进程(管理员模式)
taskkill /F /PID PID号
步骤
1.配置环境变量,将mysqld所在路径添加到path中
D:\MySQL\mysql-5.6.48-winx64\mysql-5.6.48-winx64\bin
2.将mysql服务端mysqld制作成开机自启动的服务
打开cmd,输入mysqld --install
# 移除mysql服务:mysql --remove
[mysqld] : mysql服务端,启动mysql服务加载的配置
[mysql] :mysql客户端,启动mysql加载的配置
[client] :其他客户端
统一编码配置,在目录下新建my.ini
文件,写入以下内容
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
# 然后重启服务
# \s查看
配置用户名和密码,登录可以不用输入(可选)
[mysql]
user="root"
password=[密码]
# 下载好的MySQL初始没有密码,可以设置新密码,
# 在cmd中,注意-uroot和-p[oldpwd]是整体
mysqladmin -uroot -p[oldpwd] password [newpwd]
# 登录mysql修改
mysql -u root -p 登录后
set password for username@localhost = password(newpwd);
# set password for root@localhost = password('7410');
1. 先关闭mysql服务
# 命令行启动,原理是跳过登录密码验证功能
2. mysqld --skip-grant-tables
3.无密码登录:mysql -uroot -p
4.修改当前用户的密码(mysql文件夹中的user表):update mysql.user set password=password(新密码) where user='root' and host='localhost'; # 括号内写密码('1234')
5.将修改数据刷到硬盘:flush privileges;
6.重新启动服务就可以正常校验登录了,登录
大部分程序的业务逻辑都是增删改查,如果内容较多展示补全出现错乱的情况 可以在语句后面加\G
# 增加数据库
create database 数据库名;
create database 数据库名 charset ='gbk'; # 设置库的字符集编码
# 查看数据库
show database; # 查所有数据库
show create database 数据库名; # 查单个
# 修改数据库
alter database 数据库名 charset='gbk';
# 删除数据库
drop database [数据库名];
操作表,需要指定该表所在的库(文件夹)
# 查看当前所在库的名字
select database();
# 切换库
use 数据库名;
# 增加表
create table 表名(字段1,字段2);
create table t1(id int,name char(4));
# 删除表
drop table [表名];
# 修改表
alter table 表名 rename 新表名 ;
alter table 表名 change 字段名 新字段名 类型;
alter table 表名 modify 字段 字段类型 ;
alter table t1 modify name char(16);
# 查看表
show tables; # 查看库下所有表
show create table 表名; # 查看单表
desc 表名; # 查看表的详细字段信息
# 在一个数据库操作另外一个数据库内的表,可以不use
数据库名.表名
操作数据,先确定库,在确定表,在操作数据
# 增加数据
insert into 表名 values(value1, value2,···);
insert into t1 values(1,'hammer') # 插入单个
insert into t1 values(1,'hammer'),(2,'ze'); # 插入多个
# 查看数据
select * from 表名; # 查看所有数据
select 字段名 from 表名;
select name from t1; # 获取t1表中的所有name值
# 修改数据
update 表名 set 字段名='值' where 字段条件
update t1 set name='hammer' where id>1; # id大于1的name修改成hammer
# 删除数据
delete from 表名; # 删除表内所有数据
delete from 表名 where 条件;
delete from t1 where id>1; # 将id>1的数据删除
delete from t1 where name='hammer';
日常生活中文件格式有很多种,针对不同文件的格式会有对应不同存储方式和处理机制,针对不同的数据应该有对应的不同处理机制来存储;
InnoDB
:MySQL5.5版本之后默认的存储引擎(默认)MyISAM
:MySQL5.5版本之前默认的存储引擎,比InnoDB快,但是InnoDB更安全show engines;
mysql> show engines;
InnoDB :DEFAULT(默认的) Supports transactions(支持事物), row-levellocking(行锁), and foreign keys(外键)
create table 表名(类型,字段) engine=[引擎名]
# 验证不同的存储引擎在存储表的时候,异同点
create table t1(id int) engine=innodb;
create table t2(id int) engine=myisam;
create table t3(id int) engine=blackhole;
create table t4(id int) engine=memory;
# 文件区别如下图
# 存数据
insert into t1 values(1);
insert into t2 values(1);
insert into t3 values(1);
insert into t4 values(1);
# 重启服务查看
select * from t1;
+------+
| id |
+------+
| 1 |
+------+
select * from t2;
+------+
| id |
+------+
| 1 |
+------+
select * from t3; # 内存中会消失
Empty set (0.00 sec)
select * from t4; # "黑洞"存啥消失啥
Empty set (0.00 sec)
运算符 | 描述 | 示例 |
---|---|---|
= | 等于 | WHERE emp_id = 1 |
!= | 不等于 | WHERE sex != '男' |
> | 大于 | WHERE salary > 10000 |
< | 小于 | WHERE hire_date >= DATE '2018-01-01' |
>= | 大于等于 | WHERE bonus < 15000 |
<= | 小于等于 | WHERE dept_id <= 2 |
BETWEEN | 位于范围之内 | WHERE salary BETWEEN 10000 AND 15000 |
IN | 属于列表之内 | WHERE emp_name IN ('hammer', 'hans', 'jason') |
expression IS NULL;
expression IS NOT NULL;
# 注意判断空值不能使用等于或者不等于;
SELECT emp_name, manager
FROM employee
WHERE manager = NULL; # 这是错误的
这个错误的原因在于将一个值与一个未知的值进行数学比较,结果仍然未知;即使是将两个空值进行比较,结果也是未知;
# 错误示例
NULL = 5;
NULL = NULL;
NULL != NULL;
如果表达式 expression 的值为空,IS NULL 返回真,IS NOT NULL 返回假;如果表达式的值不为空,IS NULL 返回假,IS NOT NULL 返回真;
select * from self_info where id is not null;
+------+--------+
| id | name |
+------+--------+
| 1 | hammer |
| 2 | hans |
+------+--------+
当需要查找的信息不太确定时,例如只记住了某个员工姓名的一部分,可以使用模糊查找的功能进行搜索。SQL 提供了两种模糊匹配的方法:LIKE 运算符和正则表达式函数;
LIKE 用于指定一个模式,并且返回匹配该模式的数据
%
:百分号可以匹配零个或者多个任意字符-
:下划线可以匹配一个任意字符mysql> select name from self_info where name like '%mmer';
+--------+
| name |
+--------+
| hammer |
+--------+
mysql> select name from self_info where name like 'han_';
+------+
| name |
+------+
| hans |
+------+
转义字符可以将通配符“%”
和“_”
进行转义,将它们当作普通字符使用转义字符\
mysql> select name from self_info where name like '\%';
+------+
| name |
+------+
| % |
+------+
注意::
正则表达式用于检索或者替换符合某个模式(规则)的文本
SELECT email
FROM t_regexp
WHERE REGEXP_LIKE(email, '^[a-zA-Z0-9]+[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,4}$');
email |
--------------------------|
TEST@shuguo.com |
123.test@shuguo-sanguo.org|
5.7版本之后默认开启了严格模式,规定多少宽度,就插入多少数据,超出报错
这里是5.6版本设置一下严格模式,保证数据格式的正确性,规定多少存多少
show variables like "%mode";
mysql> show variables like '%mode';
+----------------------------+------------------------+
| Variable_name | Value |
+----------------------------+------------------------+
| binlogging_impossible_mode | IGNORE_ERROR |
| block_encryption_mode | aes-128-ecb |
| gtid_mode | OFF |
| innodb_autoinc_lock_mode | 1 |
| innodb_strict_mode | OFF |
| pseudo_slave_mode | OFF |
| slave_exec_mode | STRICT |
| sql_mode | NO_ENGINE_SUBSTITUTION |
+----------------------------+------------------------+
修改严格模式(可选)
set session
set global
# 修改严格模式
set global sql_mode = 'STRICT_TRANS_TABLES';
# 取消剔除空格:set global sql_mode = 'STRICT_TRANS_TABLES,PAD_CHAR_TO_FULL_LENGTH';
# 修改完重新登录
格式:create table 表名 (
字段1 类型(宽度) 约束条件,
字段2 类型(宽度) 约束条件,
字段3 类型(宽度) 约束条件
···
)
mysql> create table t5(name char);
mysql> desc t5; # 宽度默认为1
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| name | char(1) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
insert into t5 values('hammer'); # 插入值
mysql> select *from t5;
+------+
| name |
+------+
| h |
+------+
# 只能插入一个字符,不同版本不同限制,不同效果
# 5.7版本之后默认开启了严格模式,规定多少宽度,就插入多少数据,超出报错
约束条件
desc查看表结构,查看是否可以插入空值
mysql> desc t5;
+-------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| name | char(1) | YES | | NULL | |
+-------+---------+------+-----+---------+-------+
* null yes:可以插入控制
每个数据类型都有默认宽度的限制,整型是个特例,比如int(8)
,如果设置该宽度,数字超出了8位,有几位就存几位,没超过8位不足的用空格填充至8位
creat table t7(id int(8));
insert into t7 values(1234); # 不足8个用空格填充
insert into t7 values(123456789); # 超过8位也ok
# 用0填充不够得位数
create table t8(id int(8) unsigned zerofill);
# 约束条件位无符号和0填充
insert into t8 values(1);
有符号直接加类型即可,无符号关键字unsigned
,0填充关键字zerofill
整型字段定义阶段,不需要加括号,默认宽度就够用了
# 有符号
create table 表名(字段 类型);
# 无符号
create table 表名(字段 类型,unsigned);
# 示例
create table t6(id tinyint);
insert into t6(-129),(256);
create table t7(id tinyint,unsigned);
insert into t7 values(-1),(256);
整型(5种)和浮点型(3种)
类型 | 大小 | 范围(有符号) | 范围(无符号) | 用途 |
---|---|---|---|---|
TINYINT | 1 Bytes | (-128,127) | (0,255) | 小整数值 |
SMALLINT | 2 Bytes | (-32 768,32 767) | (0,65 535) | 大整数值 |
MEDIUMINT | 3 Bytes | (-8 388 608,8 388 607) | (0,16 777 215) | 大整数值 |
INT或INTEGER | 4 Bytes | (-2 147 483 648,2 147 483 647) | (0,4 294 967 295) | 大整数值 |
BIGINT | 8 Bytes | (-9,223,372,036,854,775,808,9 223 372 036 854 775 807) | (0,18 446 744 073 709 551 615) | 极大整数值 |
FLOAT | 4 Bytes | (-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38) | 0,(1.175 494 351 E-38,3.402 823 466 E+38) | 单精度 浮点数值 |
DOUBLE | 8 Bytes | (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) | 0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) | 双精度 浮点数值 |
DECIMAL | 对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2 | 依赖于M和D的值 | 依赖于M和D的值 | 小数值 |
浮点型demo,三种浮点型的精度不一样
float(255,30) # 总共255位,小数占30位
double(255,30) # 总共255位,小数占30位
decimal(255,30) # 总共255位,小数占30位
# 精确度
float < double < decimal
类型 | 大小 ( bytes) | 范围 | 格式 | 用途 |
---|---|---|---|---|
DATE | 3 | 1000-01-01/9999-12-31 | YYYY-MM-DD | 日期值 |
TIME | 3 | '-838:59:59'/'838:59:59' | HH:MM:SS | 时间值或持续时间 |
YEAR | 1 | 1901/2155 | YYYY | 年份值 |
DATETIME | 8 | 1000-01-01 00:00:00/9999-12-31 23:59:59 | YYYY-MM-DD HH:MM:SS | 混合日期和时间值 |
TIMESTAMP | 4 | 1970-01-01 00:00:00/2038结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07 | YYYYMMDD HHMMSS | 混合日期和时间值,时间戳 |
类型 | 大小 | 用途 |
---|---|---|
CHAR | 0-255 bytes | 定长字符串 |
VARCHAR | 0-65535 bytes | 变长字符串 |
TINYBLOB | 0-255 bytes | 不超过 255 个字符的二进制字符串 |
TINYTEXT | 0-255 bytes | 短文本字符串 |
BLOB | 0-65 535 bytes | 二进制形式的长文本数据 |
TEXT | 0-65 535 bytes | 长文本数据 |
MEDIUMBLOB | 0-16 777 215 bytes | 二进制形式的中等长度文本数据 |
MEDIUMTEXT | 0-16 777 215 bytes | 中等长度文本数据 |
LONGBLOB | 0-4 294 967 295 bytes | 二进制形式的极大文本数据 |
LONGTEXT | 0-4 294 967 295 bytes | 极大文本数据 |
ps:char(n) 和 varchar(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30) 就可以存储 30 个字符,超出报错
CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。
BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序和比较基于列值字节的数值值。
BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。
有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。对应的这 4 种 BLOB 类型,可存储的最大长度不同,可根据实际情况选择。
分类
枚举(enum):多选一
比如性别选择
集合(set):多选多
比如爱好选择
使用如下
create table user(
id int,
name varchar(16),
gender enum('male','female','others'), # 枚举类型
hobby set('read','basketball','skiing','baseball','others') # 集合类型
)
# 插入的时候只能插入枚举类型指定的字段
insert into user values(1,'hammer','male'); # 正确的
insert into user values(2,'hans','xx'); # 错误的
# 集合可以写一个或者多个,但是只能写集合定义好的
insert into user values(3,'ze','male','skiing,baseball'); # 正确的
insert into user values(4,'mei','male','eat'); # 不正确的
目前我正在构建相当大的网络系统,我需要强大的 SQL 数据库解决方案。我选择 Mysql 而不是 Postgres,因为一些任务需要只读(MyISAM 引擎)而其他任务需要大量写入(InnoDB)。
我在 mysql 中使用如下命令。当它显示表格数据时,它被格式化为一个非常干净的表格,间距均匀且 |作为列分隔符。 SELECT * FROM TABLE_NAME; 当我从 CLI 运行命令时,如下
我知道这个问题之前已经被问过好几次了,我已经解决了很多问题,但到目前为止没有任何效果。 MySQL 试图将自身安装到的目录 (usr/local/mysql) 肯定有问题。关于我的错误的奇怪之处在于我
以下是我的 SQL 数据结构,我正在尝试如下两个查询: Select Wrk_ID, Wrk_LastName, Skill_Desc from Worker, Skill where
我们有一个本地 mysql 服务器(不在公共(public)域上),并希望将该服务器复制到我们拥有的 google 云 sql 实例。我的问题是:1.这可能吗?2.我们的本地服务器只能在本地网络上访问
我有一个表(test_table),其中一些字段值(例如字段 A、B 和 C)是从外部应用程序插入的,还有一个字段(字段 D),我想从现有表(store_table)插入其值,但在插入前者(A、B 和
我想创建一个 AWS RDS 实例,然后使用 terraform 管理数据库用户。因此,首先,我创建了一个 RDS 实例,然后使用创建的 RDS 实例初始化 mysql 提供程序,以进一步将其用于用户
当用户在我的网站上注册时,他们会在我的一个数据库中创建自己的表格。该表存储用户发布的所有帖子。我还想做的是也为他们生成自己的 MySql 用户——该用户仅有权从他们的表中读取、写入和删除。 创建它应该
我有一个关于 ColdFusion 和 Mysql 的问题。我有两个表:PRODUCT 和 PRODUCT_CAT。我想列出包含一些标记为:IS_EXTRANET=1 的特殊产品的类别。所以我写了这个
我想获取 recipes_id 列的值,以获取包含 ingredient_id 的 2,17 和 26 条目的值。 假设 ingredient_id 2 丢失则不获取记录。 我已经尝试过 IN 运算符
在 Ubuntu 中,我通常安装两者,但 MySQL 的客户端和服务器之间有什么区别。 作为奖励,当一个新语句提到它需要 MySQL 5.x 时,它是指客户端、服务器还是两者兼而有之。例如这个链接ht
我重新访问了我的数据库并注意到我有一些 INT 类型的主键。 这还不够独特,所以我想我会有一个指导。 我来自微软 sql 背景,在 ssms 中你可以 选择类型为“uniqeidentifier”并自
我的系统上有 MySQL,我正在尝试确定它是 Oracle MySQL 还是 MySQL。 Oracle MySQL 有区别吗: http://www.oracle.com/us/products/m
我是在生产 MySQL 中运行的应用程序的新维护者。之前的维护者已经离开,留下的文档很少,而且联系不上了。 我面临的问题是执行以下请求大约需要 10 秒: SELECT COUNT(*) FROM `
我有两个位于不同机器上的 MySQL 数据库。我想自动将数据从一台服务器传输到另一台服务器。比方说,我希望每天早上 4:00 进行数据传输。 可以吗?是否有任何 MySQL 内置功能可以让我们做到这一
有什么方法可以使用 jdbc 查询位于 mysql 根目录之外的目录中的 mysql 表,还是必须将它们移动到 mysql 根目录内的数据库文件夹中?我在 Google 上搜索时没有找到任何东西。 最
我在 mysql 数据库中有两个表。成员和 ClassNumbers。两个表都有一个付费年份字段,都有一个代码字段。我想用代码数字表中的值更新成员表中的付费年份,其中成员中的代码与 ClassNumb
情况:我有 2 台服务器,其中一台当前托管一个实时 WordPress 站点,我希望能够将该站点转移到另一台服务器,以防第一台服务器出现故障。传输源文件很容易;传输数据库是我需要弄清楚如何做的。两台服
Phpmyadmin 有一个功能是“复制数据库到”..有没有mysql查询来写这个函数?类似于将 db A 复制到新的 db B。 最佳答案 首先创建复制数据库: CREATE DATABASE du
我有一个使用 mySQL 作为后端的库存软件。我已经在我的计算机上对其进行了测试,并且运行良好。 当我在计算机上安装我的软件时,我必须执行以下步骤: 安装 mySQL 服务器 将用户名指定为“root
我是一名优秀的程序员,十分优秀!