用户自定义变量
- 局部变量--->只在当前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》》》
智者见智,仁者见仁,一个好的价值观念会让你懂得许多,学会更多,得到很多