网站首页 > java教程 正文
本文源自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》》》
智者见智,仁者见仁,一个好的价值观念会让你懂得许多,学会更多,得到很多
猜你喜欢
- 2024-12-08 「JAVA」kdb数据库进行归档日志导致连接不上
- 2024-12-08 Springboot如何连接达梦数据库,超详细,附源码
- 2024-12-08 Java 与 MySQL 数据库连接池优化:提升数据访问效率的关键策略
- 2024-12-08 Java 连接操作 MySQL 数据库(增删查改操作)
- 2024-12-08 java数据库连接技术(JDBC)
- 2024-12-08 java常用代码分享-jdbc的数据库连接
你 发表评论:
欢迎- 05-27JavaScript 中的运算符优先级
- 05-27Java程序员必备:运算符使用中的八大实战要点
- 05-27Java运算符优先级表
- 05-272025-04-29:高度互不相同的最大塔高和。用go语言,给定一个数组
- 05-27PHP排序算法:计数、选择、插入、归并、快速、冒泡、希尔、堆
- 05-27Python高级排序算法应用
- 05-27用好RANK函数 跨表排名不用愁
- 05-27十大排序算法时空复杂度
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)