Mysql8.0安装以及递归表达式使用

2024-09-05 08:36

本文主要是介绍Mysql8.0安装以及递归表达式使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mysql安装

以centos7为例安装!

安装wget

yum install wget -y

给CentOS添加rpm源,并且选择较新的源

官网地址

wget dev.mysql.com/get/mysql84-community-release-el7-1.noarch.rpm
e67b28ebdbb9b107b477e83601c3070e.png

下载安装的rpm源文件

yum install mysql84-community-release-el7-1.noarch.rpm -y

使用yum安装mysql

yum install mysql-community-server -y

mysql相关的设置

启动服务以及开机自启

#启动mysql服务
service mysqld start
#设置mysql开机启动
chkconfig mysqld on

修改密码

变量名
validate_password.changed_characters_percentage0
validate_password.check_user_nameon
validate_password.length8
validate_password.mixed_case_count1
validate_password.number_count1
validate_password.policyMEDIUM
validate_password.special_char_count1
##查看临时密码
grep "password" /var/log/mysqld.log
## 临时密码登录
mysql -uroot -p
##修改密码策略和密码
set global validate_password.policy=LOW;
set global validate_password.length=1;
set global validate_password.special_char_count=0;
set global validate_password.mixed_case_count=0 ;
set global validate_password.number_count =0;ALTER USER 'root'@'localhost' IDENTIFIED BY 'rootA@123456';

授权 8.0有区别

#创建用户
create user 'echo'@'%' identified by '123456';
# 授权
grant all privileges on *.* to 'echo'@'%' with grant option;
# 刷新权限
FLUSH PRIVILEGES;

递归表达式ETC

递归表达式是一种特殊的子查询,它能够引用其本身的查询结果。它包含两部分

SELECT ...      -- return initial row set
UNION ALL
SELECT ...      -- return additional row sets

例如:

WITH RECURSIVE cte (n) AS
(SELECT 1UNION ALLSELECT n + 1 FROM cte WHERE n < 5
)
SELECT * FROM cte;
e10c8802604f3357121402e6adef8eae.png

典型应用

斐波那契数列

WITH RECURSIVE fibonacci (n, fib_n, next_fib_n) AS
(SELECT 1, 0, 1UNION ALLSELECT n + 1, next_fib_n, fib_n + next_fib_nFROM fibonacci WHERE n < 10
)
SELECT * FROM fibonacci;
4b38d671fc1a1f1e8cd9ed967c0c4110.png

时间序列生成

WITH RECURSIVE dates (date) AS
(SELECT MIN(date) FROM salesUNION ALLSELECT date + INTERVAL 1 DAY FROM datesWHERE date + INTERVAL 1 DAY <= (SELECT MAX(date) FROM sales)
)
SELECT * FROM dates;

层次结构遍历

以评论回复为例

WITH RECURSIVE CommentHierarchy AS (SELECT c.comment_id,c.post_id,c.user_id,c.parent_id,c.content,c.created_at,c.updated_at,0 AS levelsFROM Comments cWHERE c.parent_id IS NULLUNION ALLSELECT c.comment_id,c.post_id,c.user_id,c.parent_id,CONCAT(ch.content,'->',c.content) content,c.created_at,c.updated_at,ch.levels + 1 AS levelsFROM Comments cINNER JOIN CommentHierarchy ch ON c.parent_id = ch.comment_id
)
SELECT * FROM CommentHierarchy ORDER BY post_id, levels, created_at;
ca3619e0e45071daec89d1cfa6aef6e4.png

往期推荐

一文带你springai+ollama实现chat

大型语言模型(Large Language Model, LLM)了解一下?

常用的JVM参数与命令你知道吗?

推荐两款程序员高效工作神器

Git命令基操必须要会!

非常nice! IDEA远程Debug调试程序

DataX二次开发之达梦数据库插件


这篇关于Mysql8.0安装以及递归表达式使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138461

相关文章

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定