存儲過程與視圖的比較--并且在mybatis中的實(shí)現(xiàn)過程

雇員基本信息表
雇員薪水信息表

兩張表的聯(lián)立視圖查詢:

創(chuàng)建視圖的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 
查詢效果圖
創(chuàng)建存儲過程的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的創(chuàng)建效果圖
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>
    <!-- 調(diào)用存儲過程查詢 -->
    <select id="loadByEmployeeId" parameterType="Long" statementType="CALLABLE" resultMap="BaseResultMap">
        {call employee_salary_function(#{employeeId,jdbcType=BIGINT,mode=IN})}
    </select>
    
    <!-- 調(diào)用視圖查詢 -->
    <select id="loadByEmployeeIdView" resultMap="BaseResultMap">
        select * from v_employee_salary where employee_id=#{employeeId,jdbcType=BIGINT}
    </select>
</mapper>
實(shí)體類:

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:根據(jù)雇員的id獲取他的工資情況,存儲過程的調(diào)用
     * @author JM 
     * 2016-12-14 下午11:17:54
     * @param id
     * @return   
     * List<TEmployeeSalary>
     */
    public List<TEmployeeSalary> loadByEmployeeId(@Param("employeeId")Long id);
    
    /**
     * loadByEmployeeIdView:根據(jù)雇員的id獲取他的工資情況,視圖的調(diào)用
     * @author JM 
     * 2016-12-14 下午11:40:36
     * @param id
     * @return   
     * List<TEmployeeSalary>
     */
    public List<TEmployeeSalary> loadByEmployeeIdView(@Param("employeeId")Long id); 
}

以上就是使用mybatis种蝶,調(diào)用視圖查詢以及存儲過程的實(shí)現(xiàn)代碼。
許多情況下骨田,對數(shù)據(jù)庫進(jìn)行多表查詢可以使用視圖進(jìn)行聯(lián)系多表藕甩,但是不建議使用視圖進(jìn)行查詢(因?yàn)椴豢梢暂斎雲(yún)?shù),每次查詢都需要全部查出來然后在挑選出符合條件的數(shù)據(jù)园蝠,這樣大大拖慢了查詢的速度)电湘,調(diào)用存儲過程進(jìn)行多表查詢的好處就是先進(jìn)性篩選然后在返回數(shù)據(jù)每庆,這樣的查詢速度在數(shù)據(jù)量很大的情況下快的不是一星半點(diǎn)筐带。
雖然存儲過程的使用可以大大提高查詢速率,但是對于頻繁操作的表本人強(qiáng)烈建議添加索引缤灵,這樣效率更高伦籍。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市凤价,隨后出現(xiàn)的幾起案子鸽斟,更是在濱河造成了極大的恐慌,老刑警劉巖利诺,帶你破解...
    沈念sama閱讀 221,820評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件富蓄,死亡現(xiàn)場離奇詭異,居然都是意外死亡慢逾,警方通過查閱死者的電腦和手機(jī)立倍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,648評論 3 399
  • 文/潘曉璐 我一進(jìn)店門灭红,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人口注,你說我怎么就攤上這事变擒。” “怎么了寝志?”我有些...
    開封第一講書人閱讀 168,324評論 0 360
  • 文/不壞的土叔 我叫張陵娇斑,是天一觀的道長。 經(jīng)常有香客問我材部,道長毫缆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,714評論 1 297
  • 正文 為了忘掉前任乐导,我火速辦了婚禮苦丁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘物臂。我一直安慰自己旺拉,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,724評論 6 397
  • 文/花漫 我一把揭開白布棵磷。 她就那樣靜靜地躺著蛾狗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪泽本。 梳的紋絲不亂的頭發(fā)上淘太,一...
    開封第一講書人閱讀 52,328評論 1 310
  • 那天姻僧,我揣著相機(jī)與錄音规丽,去河邊找鬼。 笑死撇贺,一個胖子當(dāng)著我的面吹牛赌莺,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播松嘶,決...
    沈念sama閱讀 40,897評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼艘狭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了翠订?” 一聲冷哼從身側(cè)響起巢音,我...
    開封第一講書人閱讀 39,804評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎尽超,沒想到半個月后官撼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,345評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡似谁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,431評論 3 340
  • 正文 我和宋清朗相戀三年傲绣,在試婚紗的時候發(fā)現(xiàn)自己被綠了掠哥。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,561評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡秃诵,死狀恐怖续搀,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情菠净,我是刑警寧澤禁舷,帶...
    沈念sama閱讀 36,238評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站毅往,受9級特大地震影響榛了,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜煞抬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,928評論 3 334
  • 文/蒙蒙 一霜大、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧革答,春花似錦战坤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,417評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至溪食,卻和暖如春囊卜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背错沃。 一陣腳步聲響...
    開封第一講書人閱讀 33,528評論 1 272
  • 我被黑心中介騙來泰國打工栅组, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人枢析。 一個月前我還...
    沈念sama閱讀 48,983評論 3 376
  • 正文 我出身青樓玉掸,卻偏偏與公主長得像,于是被迫代替她去往敵國和親醒叁。 傳聞我的和親對象是個殘疾皇子司浪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,573評論 2 359

推薦閱讀更多精彩內(nèi)容