美文网首页游戏开发
存储过程与视图的比较--并且在mybatis中的实现过程

存储过程与视图的比较--并且在mybatis中的实现过程

作者: higher2017 | 来源:发表于2016-12-15 00:00 被阅读1027次
雇员基本信息表 雇员薪水信息表

两张表的联立视图查询:

创建视图的sql语句:
SELECT
t_employee_info.employee_name,
t_employee_info.employee_age,
t_employee_info.employee_address,
t_salary_info.salary_id,
t_salary_info.time,
t_salary_info.money,
t_employee_info.employee_id
FROM
t_employee_info
INNER JOIN t_salary_info ON t_salary_info.employee_id = t_employee_info.employee_id
ORDER BY
t_salary_info.money DESC 
查询效果图
创建存储过程的sql语句:
BEGIN
    #Routine body goes here...
select 
t_employee_info.employee_name,
t_employee_info.employee_age,
t_employee_info.employee_address,
t_employee_info.employee_id,
t_salary_info.salary_id,
t_salary_info.time,
t_salary_info.money
FROM t_employee_info INNER JOIN t_salary_info 
ON t_salary_info.employee_id = t_employee_info.employee_id
where t_employee_info.employee_id=employee_id
ORDER BY
t_salary_info.money DESC limit 10;
END
存储过程employee_salary_function的创建效果图
mybatis的mapper.xml代码:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.jm.dao.TEmployeeSalaryMapper">
    <resultMap id="BaseResultMap" type="com.jm.model.TEmployeeSalary">
        <result column="employee_id" property="employeeId" jdbcType="BIGINT" />
        <result column="employee_name" property="employeeName" jdbcType="VARCHAR" />
        <result column="employee_age" property="employeeAge" jdbcType="INTEGER" />
        <result column="employee_address" property="employeeAddress" jdbcType="VARCHAR" />
        <result column="salary_id" property="salaryId" jdbcType="BIGINT" />
        <result column="time" property="time" jdbcType="BIGINT" />
        <result column="money" property="money" jdbcType="BIGINT" />    
    </resultMap>
    <!-- 调用存储过程查询 -->
    <select id="loadByEmployeeId" parameterType="Long" statementType="CALLABLE" resultMap="BaseResultMap">
        {call employee_salary_function(#{employeeId,jdbcType=BIGINT,mode=IN})}
    </select>
    
    <!-- 调用视图查询 -->
    <select id="loadByEmployeeIdView" resultMap="BaseResultMap">
        select * from v_employee_salary where employee_id=#{employeeId,jdbcType=BIGINT}
    </select>
</mapper>
实体类:

public class TEmployeeSalary {
    
    private Long employeeId;
    private String employeeName;
    private Integer employeeAge;
    private String employeeAddress;
    private Long salaryId;
    private Long time;
    private Long money;
    
    public String toString(){
        return "employeeId:"+employeeId+", "+"employeeName:"+employeeName+", "+"employeeAge:"+employeeAge+", "+"employeeAddress:"+employeeAddress+", "+
                "salaryId:"+salaryId+", "+"time:"+time+", "+"money:"+money+"-----------";
    }
    
    public Long getEmployeeId() {
        return employeeId;
    }

    public void setEmployeeId(Long employeeId) {
        this.employeeId = employeeId;
    }

    public String getEmployeeName() {
        return employeeName;
    }

    public void setEmployeeName(String employeeName) {
        this.employeeName = employeeName;
    }

    public Integer getEmployeeAge() {
        return employeeAge;
    }

    public void setEmployeeAge(Integer employeeAge) {
        this.employeeAge = employeeAge;
    }

    public String getEmployeeAddress() {
        return employeeAddress;
    }

    public void setEmployeeAddress(String employeeAddress) {
        this.employeeAddress = employeeAddress;
    }

    public Long getSalaryId() {
        return salaryId;
    }

    public void setSalaryId(Long salaryId) {
        this.salaryId = salaryId;
    }

    public Long getTime() {
        return time;
    }

    public void setTime(Long time) {
        this.time = time;
    }

    public Long getMoney() {
        return money;
    }

    public void setMoney(Long money) {
        this.money = money;
    }
    
}
dao:
import java.util.List;
import org.apache.ibatis.annotations.Param;
import com.jm.model.TEmployeeSalary;

public interface TEmployeeSalaryMapper {
    /**
     * loadByEmployeeId:根据雇员的id获取他的工资情况,存储过程的调用
     * @author JM 
     * 2016-12-14 下午11:17:54
     * @param id
     * @return   
     * List<TEmployeeSalary>
     */
    public List<TEmployeeSalary> loadByEmployeeId(@Param("employeeId")Long id);
    
    /**
     * loadByEmployeeIdView:根据雇员的id获取他的工资情况,视图的调用
     * @author JM 
     * 2016-12-14 下午11:40:36
     * @param id
     * @return   
     * List<TEmployeeSalary>
     */
    public List<TEmployeeSalary> loadByEmployeeIdView(@Param("employeeId")Long id); 
}

以上就是使用mybatis,调用视图查询以及存储过程的实现代码。
许多情况下,对数据库进行多表查询可以使用视图进行联系多表,但是不建议使用视图进行查询(因为不可以输入参数,每次查询都需要全部查出来然后在挑选出符合条件的数据,这样大大拖慢了查询的速度),调用存储过程进行多表查询的好处就是先进性筛选然后在返回数据,这样的查询速度在数据量很大的情况下快的不是一星半点。
虽然存储过程的使用可以大大提高查询速率,但是对于频繁操作的表本人强烈建议添加索引,这样效率更高。

相关文章

  • 存储过程与视图的比较--并且在mybatis中的实现过程

    两张表的联立视图查询: 创建视图的sql语句: 创建存储过程的sql语句: mybatis的mapper.xml代...

  • 视图与存储过程

    在SQL学习中遇到了视图与存储过程两个概念,粗略来看,两者有着很大的相似性,都类似于等待调用的函数,但是仍有一些区...

  • 视图与存储过程

    视图的创建与使用 为什么需要视图?不同人员关注不同的数据,保证信息的安全性 视图 是存储在服务器端的一个查询块,是...

  • 视图与存储过程

    一,视图 什么是视图 视图作为一张虚拟表,它相当于是一张表或多张表的数据结果集。 视图的优点 可以帮我们简化复杂的...

  • MySql中的视图、存储过程

    什么是视图 视图是一个虚拟表,就是用来查询数据的。使用视图的几个好处,不过用视图时要考虑性能的问题 简化sql语句...

  • mybatis中使用mysql存储过程注意事项

    1、navicat创建开发存储过程注意事项: 2、springboot + mybatis中调用存储过程(多个in...

  • mysql 视图与存储过程

    一.视图 1.什么是视图 视图是一个虚拟表,其内容由查询定义,和真实的表有显著区别,只有在特定条件下才可以upda...

  • mysql 视图与存储过程

    一.视图 1.什么是视图 视图是一个虚拟表,其内容由查询定义,和真实的表有显著区别,只有在特定条件下才可以upda...

  • 领域驱动设计

    存储过程 vs 表视图 vs 领域驱动 存储过程面向集合sql/存储过程编辑表指数级复杂度 表视图面向过程代码编辑...

  • MySQL视图、存储过程

    1. 创建视图一般格式:create view 视图名称 as SQL语句 2. 删除视图一般格式:drop vi...

网友评论

    本文标题:存储过程与视图的比较--并且在mybatis中的实现过程

    本文链接:https://www.haomeiwen.com/subject/zhgimttx.html