這篇文章將為大家詳細(xì)講解有關(guān)如何在ssm的dao接口中使用@Param注解,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

@Param 注解的用處:為了接口中方法的形參與xml文件中sql語句中的條件參數(shù)綁定
完全沒必要使用@Param注解
例:
public interface PaperDao {
Paper queryById(long id);
}此時(shí)相應(yīng)的xml文件中,#{}中可以填寫任意名稱
<select id="queryById" parameterType="long" resultMap="resultMap1">
SELECT paper_id,name,number,detail
FROM paper
WHERE paper_id=#{id}
</select>推薦使用@Param注解進(jìn)行參數(shù)綁定
例:
public interface PaperDao {
Paper queryById(@Param("id") long id,@Param("name") String name);}xm文件:
<select id="queryById" parameterType="long" resultMap="resultMap1">
SELECT paper_id,name,number,detail
FROM paper
WHERE paper_id=#{id} AND name=#{name}
</select>補(bǔ)充:SSM整合過程關(guān)于@Param注解使用的一些細(xì)節(jié)
1.首先先聲明一下該注解的功能,就是給參數(shù)進(jìn)行命名來找到對應(yīng)參數(shù),
舉個(gè)例子(例如在Mybatis的XXXMapper.xml文件中針對某個(gè)sql語句 比如根據(jù)id來查詢某個(gè)實(shí)體,那么假如我們傳入的參數(shù)列名為id,但是實(shí)體類的column確實(shí)userID,這時(shí)候我們可以將參數(shù)就行命名為userID,
這時(shí)候我們就可以根據(jù)這個(gè)命名找到該參數(shù),類似于該參數(shù)的一個(gè)“id”的感覺,這樣就可以將參數(shù)正確的注入sql語句中。
例如:
public int getUserDetail(@Param("userId") int id);
//這里我們就可以利用#{userId}來獲取到id的值 在執(zhí)行sql語句時(shí)候還有一個(gè)好處就是使用該注解來聲明參數(shù)時(shí),使用#{}和KaTeX parse error: Expected 'EOF', got '#' at position 25: …會報(bào)錯,但是不使用的話就只能用#?{}(一般多數(shù)情況都是#{},…${}會產(chǎn)生sql注入的問題。
但是這里我總結(jié)一個(gè)我用這個(gè)注解時(shí)候遇到的一個(gè)很坑的問題,就是在你調(diào)用某個(gè)帶有@Param注解的函數(shù)的時(shí)候,傳參數(shù)的時(shí)候就會報(bào)錯,這點(diǎn)需要注意
關(guān)于如何在ssm的dao接口中使用@Param注解就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
當(dāng)前標(biāo)題:如何在ssm的dao接口中使用@Param注解-創(chuàng)新互聯(lián)
本文路徑:http://chinadenli.net/article0/dhosoo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、網(wǎng)站內(nèi)鏈、微信小程序、移動網(wǎng)站建設(shè)、響應(yīng)式網(wǎng)站、定制開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容