MYSQL相关之不常见变量、排序函数、JDBC数据库与Java连接
mhr18 2024-09-21 19:05 23 浏览 0 评论
本文源自Recently祝祝,创自Recently祝祝。转载请标注出处
1.MYSQL变量分两类
用户自定义变量
- 局部变量--->只在当前begin/end代码块中有效
sql复制代码create procedure add
(
in a int,
in b int
)
begin
declare c int default 0;
set c = a + b;
select c as c;
end;
2.用户变量--->在客户端链接到数据库实例整个过程中用户变量都是有效的。
系统变量
- 会话变量-->会话变量的作用域与用户变量一样,仅限于当前连接。当当前连接断开后,其设置的所有会话变量均失效。@@session.变量名 或者@@local.变量名
4.全局变量-->全局变量影响服务器整体操作。@@global.变量名
DEMO解释排序函数
按员工底薪排序并且标明顺序。 按照实例模仿,可以学会排序函数的使用方式。实例下边也进行了解释。Oracle中存在row_number,rank,dense_rank函数,而Mysql中需要模仿处理,下边实例都是在Mysql中进行实现的。
DEMO1:
sql复制代码-- 排序函数
-- row_number,rank,dense_rank
USE mytest;
row_number row_number简写rn,可以根据需求进行命名 使用名为“@rn”的变量来跟踪行号。我们使用子查询 (SELECT @rn := 0) 将其初始化为 0,然后使用表达式“@rn := @rn + 1”为每一行将其递增 1。
sql复制代码-- row_number
SELECT empno,ename,sal,@rn:=@rn+1 rn
FROM emp,(SELECT @rn:=0)t1
ORDER BY sal DESC;
Demo2:
dense_rank dense_rank就是除了使用row_number-》rn,还使用了一个rank变量,rank就是下边实例中的sal.
sql复制代码-- dense_rank
SELECT empno,ename,sal,
IF(@sal=sal,@rn,@rn:=@rn+1) rn,
@sal:=sal
FROM emp,(SELECT @rn:=0,@sal:=0) t1
ORDER BY sal DESC;
检索“emp”表中所有员工的员工编号 (empno)、员工姓名 (ename) 和薪水 (sal),同时还按降序为每一行生成行号 (rn)的薪水。查询使用变量 (@rn) 来跟踪行号。在执行主查询之前,该变量在子查询 (t1) 中被初始化为 0。
DEMO3:
-- rank
sql复制代码-- rank
SELECT empno,ename,sal,@r:=@r+1,
IF(@sal=sal,@rn,@rn:=@r) rn, @sal:=sal
FROM emp,(SELECT @rn:=0, @r:=0,@sal:=0) t1 ORDER BY sal DESC;
使用变量模拟 MySQL 中 ROW_NUMBER() 函数的行为。
- “@rn”变量用于跟踪行号。
- “@r”变量用于跟踪排名。
- “@sal”变量用于跟踪以前的薪水值。
- 子查询将所有变量初始化为 0。
- SELECT 语句检索员工编号、姓名、薪水,并生成行号和级别。
- “@r”变量每行递增 1。
- IF() 函数检查当前薪水值是否与以前的薪水值相同。如果它们相同,则“@rn”变量用作当前行的排名。如果它们不同,则使用“@r”变量作为当前行的排名,并将“@rn”变量设置为“@r”的值。
- “@sal”变量用当前薪水值更新,以便在下一行进行比较。
- 结果集按薪水降序排列。
DEMO4:
sql复制代码-- 将员工的信息,按照部门和底薪排序,并标明顺序
SELECT empno,ename,deptno,sal,
IF(@sal=sal,@rn,@rn:=@rn+1),
IF(@deptno=deptno,@rn,@rn:=1) rn,
@deptno:=deptno,
@sal:=sal
FROM emp,(SELECT @rn:=0,@sal:=0,@deptno:=0) t1
ORDER BY deptno,sal DESC;
检索“emp”表中所有员工的员工编号 (empno)、员工姓名 (ename) 和薪水 (sal),同时还按降序为每一行生成行号 (rn)的薪水。
此外,它检查当前行的薪水是否与上一行的薪水相同,如果是,则为当前行分配与上一行相同的行号。使用三个变量(@rn、@r 和@sal)来跟踪行号、基于薪水的行排名以及之前的薪水值。
在执行主查询之前,变量在子查询 (t1) 中被初始化为 0。主查询首先为每一行递增 @r 变量以生成基于薪水的排名。然后它使用 IF 语句将当前薪水 (@sal) 与以前的薪水值进行比较。
如果它们相同,则为当前行分配与前一行相同的行号(@rn);否则,它使用@r 变量分配一个新的行号(@rn)。最后,它用当前行的薪水更新@sal 变量,以便在下一行进行比较。 ORDER BY 子句按薪水的降序对结果集进行排序。
JDBC数据库与Java连接
概述: JDBC是Java访问数据库的标准规范,可以为不同的关系型数据库提供统一访问,它由一组用Java语言编写的接口和类组成。
JDBC规范(掌握四个核心对象):
- DriverManager:用于注册驱动
- Connection: 表示与数据库创建的连接
- Statement: 操作数据库sql语句的对象
- ResultSet: 结果集或一张虚拟表
JDBC连接数据库基础六部
第一步:注册驱动 Class.forName("com.mysql.jdbc.Driver");
第二步:建立连接 这一步注意修改数据库名称以及密码,和数据库地址 conn=DriverManager.getConnection("jdbc:mysql://localhost/test1","root","123456");
第三步:创建Statement对象 st=conn.createStatement();
end》》》
智者见智,仁者见仁,一个好的价值观念会让你懂得许多,学会更多,得到很多
相关推荐
- Springboot数据访问(整合动态数据源)
-
Springboot整合动态数据源dynamic-datasource-spring-boot-starter基本概念这个依赖是MyBatis-Plus团队开发的动态数据源组件,它是一个基于Spri...
- 《有手就会写sql》-第1章 数据库(sql实时更新同表里某个字段的数据)
-
为啥要用数据库存放数据的方式,有很多种,常用的比如:excel,数据库等。有了excel,为啥还要用数据库呢?原因有很多。其中之一:excel存储的数据有限的,最多能存个几千万条。但一个银行的交易数据...
- DBdoctor:一款企业级数据库性能诊断工具
-
DBdoctor是一个全面覆盖开发、测试、运维等各个环节SQL审核以及数据库性能诊断与优化的监控平台。针对数据库性能诊断门槛高、耗时长的问题,DBdoctor提供了快速易用的解决方案,深入到数...
- 面试必问:MySQL死锁 是什么,如何解决?(史上最全)
-
MySQL死锁接触少,但面试又经常被问到怎么办?最近有小伙伴在面试的时候,被问了MySQL死锁,如何解决?虽然也回答出来了,但是不够全面体系化,所以,小北给大家做一下系统化、体系化的梳理,帮助大家在面...
- JAVA入门教程-第1章 概述(java入门篇)
-
大道至简-JAVA入门教程在本教程中,你将学习Java语言的基础知识。Java基础内容涵盖:Java基础概念、Java词法结构、Java数组、Java流程控制、Java字符串、Java...
- 突发消息!微软停止俄罗斯业务(微软停止服务怎么办)
-
越来越多的IT公司加入封杀俄罗斯的阵营中。数字化转型网先后关注的有(点击下方蓝字可打开文章):SAP停止俄罗斯所有业务乌克兰呼吁SAP、Oracle封杀俄罗斯,Oracle已停止在俄所有业务埃森哲停止...
- 分布式数据库设计——存储引擎原理(全)
-
摘要数据库的一个首要目标是可靠并高效地管理数据,以供人们使用。进而不同的应用可以使用相同的数据库来共享它们的数据。数据库的出现使人们放弃了为每个独立的应用开发数据存储的想法,同时,随着数据库广泛的使用...
- Java运行环境配置(java运行环境配置成功截图)
-
若要在计算机上运行Java程序,需要配置Java运行环境(JRE)或Java开发工具包(JDK)。以下是在Windows操作系统上配置Java运行环境的步骤:下载Java安装程序:前往Oracle官方...
- 分布式任务调度Celery(分布式任务调度平台)
-
本文介绍了分布式任务调度系统Celery,包括安装,开发使用,并且配合supervisor,flower等工具进行系统化部署和使用。(一)安装和代码开发使用示例一,简介Celery是一个分布式任务调度...
- Android SDK 安装与配置(android sdk安装在哪里)
-
AndroidSDK安装与配置全流程指南一、前期准备与环境要求1.系统兼容性验证o操作系统:支持Windows10/11(64位)、macOS10.14+、Ubuntu16.04+等主流...
- 高性能Linux服务器构建实战:运维监控、性能调优与集群应用
-
百万级字迹详解实战案例,篇幅因素故只展现pdf目录,完整解析获取方式在篇尾了!目录读者对象Web应用篇(1至第3章)数据备份恢复篇(4至第6章)网络存储应用篇(7和第8章)运维监控与性能优化篇(9和第...
- Vmware虚拟机迁移数据库时踩过的坑
-
从Vmware迁移数据库虚拟机到其他平台,起来后认不到asm盘,不禁傻眼了。很多时候为了保证虚拟机系统的完整可启动,在做任何变更前,领导都会要求克隆一份镜像保存,或者直接在镜像上操作。这是传统的备份理...
- Java 中 java.util.Date 与 java.sql.Date 有什么区别?
-
Java里的java.util.Date和java.sql.Date绝对是那种看起来不起眼但能搞得你Debug到半夜的“坑王”。我们先从表面上看,java.sql.Date是继承自j...
- 主流数据库的不同点在哪?MySQL和SQL Server的区别介绍
-
在本教程中,树懒君介绍了两种最普遍应用的RDBMS—MySQL和MicrosoftSQLServer。通过介绍MySQL和SQLServer的几个关键区别,希望大家能在这两者之间做出最适合自己的...
- Java安全-Java Vuls(Fastjson、Weblogic漏洞复现)
-
复现几个Java的漏洞,文章会分多篇这是第一篇,文章会分组件和中间件两个角度进行漏洞复现复现使用环境VulhubVulFocus组件Fastjson1.2.24反序列化RCEFastJson...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (74)
- oracle批量插入数据 (65)
- oracle事务隔离级别 (59)
- oracle 空为0 (51)
- oracle主从同步 (56)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)