MYSQL相关之不常见变量、排序函数、JDBC数据库与Java连接

本文源自Recently祝祝,创自Recently祝祝。转载请标注出处

1.MYSQL变量分两类

用户自定义变量

  1. 局部变量--->只在当前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.用户变量--->在客户端链接到数据库实例整个过程中用户变量都是有效的。

系统变量

  1. 会话变量-->会话变量的作用域与用户变量一样,仅限于当前连接。当当前连接断开后,其设置的所有会话变量均失效。@@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() 函数的行为。

  1. “@rn”变量用于跟踪行号。
  2. “@r”变量用于跟踪排名。
  3. “@sal”变量用于跟踪以前的薪水值。
  4. 子查询将所有变量初始化为 0。
  5. SELECT 语句检索员工编号、姓名、薪水,并生成行号和级别。
  6. “@r”变量每行递增 1。
  7. IF() 函数检查当前薪水值是否与以前的薪水值相同。如果它们相同,则“@rn”变量用作当前行的排名。如果它们不同,则使用“@r”变量作为当前行的排名,并将“@rn”变量设置为“@r”的值。
  8. “@sal”变量用当前薪水值更新,以便在下一行进行比较。
  9. 结果集按薪水降序排列。

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》》》

智者见智,仁者见仁,一个好的价值观念会让你懂得许多,学会更多,得到很多

举报
评论 0