⑴ 如何編寫Java的MyBatis框架中sql語句映射部分
1..增刪改查、參數、緩存
1.1 select 舉例如下:
查詢學員信息,一個String參數,參數標識為#{studentID},並返回一個StudentEntity類型的對象
<select id="getStudent" parameterType="String" resultMap="studentResultMap">
SELECT ST.STUDENT_ID,
ST.STUDENT_NAME,
ST.STUDENT_SEX,
ST.STUDENT_BIRTHDAY,
ST.CLASS_ID
FROM STUDENT_TBL ST
WHERE ST.STUDENT_ID = #{studentID}
</select>
1.2 insert 舉例如下:
插入數據,一個String參數,參數標識為#{studentID},並返回一個StudentEntity類型的對象。
<insert id="insertStudent" parameterType="StudentEntity">
INSERT INTO STUDENT_TBL (STUDENT_ID,
STUDENT_NAME,
STUDENT_SEX,
STUDENT_BIRTHDAY,
CLASS_ID)
VALUES (#{studentID},
#{studentName},
#{studentSex},
#{studentBirthday},
#{classEntity.classID})
</insert>
1.3 update 舉例如下:
更新學員信息
<update id="updateStudent" parameterType="StudentEntity">
UPDATE STUDENT_TBL
SET STUDENT_TBL.STUDENT_NAME = #{studentName},
STUDENT_TBL.STUDENT_SEX = #{studentSex},
STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday},
STUDENT_TBL.CLASS_ID = #{classEntity.classID}
WHERE STUDENT_TBL.STUDENT_ID = #{studentID};
</update>
1.4 delete 舉例如下:
刪除學員信息:
<delete id="deleteStudent" parameterType="StudentEntity">
DELETE FROM STUDENT_TBL WHERE STUDENT_ID = #{studentID}
</delete>
2.ResultMap
SQL映射xml文件是為了放置所有sql語句,需要定義一個workspace,正常是介面類的路徑。SQL語句映射文件寫好後,需要在MyBatis配置文件mappers標簽中引用。
舉例如下:
<mappers>
<mapper resource="cn/te/ninixie/manager/data/mappers/UserMapper.xml" />
<mapper resource="cn/te/ninixie/manager/data/mappers/StudentMapper.xml" />
<mapper resource="cn/te/ninixie/manager/data/mappers/ClassMapper.xml" />
<mapper resource="cn/te/ninixie/manager/data/mappers/TeacherMapper.xml" />
</mappers>
當Java介面與xml文件在一個相對路徑下,那麼MyBaits配置文件的napper中可以不用聲明。
ResultMaps的作用,就是簡單的語句而不需要多餘的結果映射,更多復雜的語句,除了只要一些絕對必須的語句描述關系以外,就不需要其它的了。
resultMap屬性:type為java實體類;id為此resultMap的標識。
resultMap可以設置的映射:
2.1 constructor:用來將結果發射給一個實例化好的類的構造器
idArg_ID 參數:將結果集標記為ID,為了方便全局調用
arg –反射到構造器的通常結果
2.2 id結果,將結果集標記為ID,為了方便全局調用
2.3 result:反射到JavaBean的普通結果
2.4 association:復雜類型的結合,多個結果合成的類型
2.5 collection:復雜類型結合
2.6 resultMap的集合,也可以引用到其他
2.7 discriminator:使用一個結果值為了決定使用哪個結果集。
⑵ mybatis設置sql通過什麼標簽
設置數據類型的話,以製作的可變數據標簽為例子,設置的話需要在軟體上方「資料庫設置」,添加對應的數據類型,之後在彈出的對應窗口中,通過選擇電腦上面的資料庫類型文件,之後今天添加即可。
⑶ mybatis映射文件中,以下哪個標簽是引入其他自定義sql片段的標簽
</sql>
<select id="find" resultType="*" resultMap="*">
<include refid="select"/>
</select>
⑷ MyBatis 中SQL語句怎麼樣使用兩種類型的參數帶條件查詢
最簡單的直接設置resultType=「map」,得到的就是一個List<Map<String,Object>>
每一個Map的key就是查詢結果的列名,也就是表的欄位名。當然sql語句中最好as一下
復雜一點可以自定義一個resultMap標簽
<resultMap id="result" type="java.util.Map">
<result property="c1" column="column1"/>
<result property="c2" column="column2"/>
</resultMap>
其中result可以自定義,select標簽中的resultMap="result",和上面的resultMap標簽的id對應
property設置的是自定義的欄位名稱,也就是結果集中每一個Map的key
column設置查詢結果的欄位名稱
然後通過
for(List<Map<String,Object> map:list){
map.get("c1");//獲取c1對應的欄位的值
。。。
}
⑸ mybatis中動態sql執行原理
解釋器模式: 初始化過程中構建出抽象語法樹,請求處理時根據參數對象解釋語法樹,生成sql語句。
工廠模式: 為動態標簽的處理方式創建工廠類(SqlTagHandlerFactory),根據標簽名稱獲取對應的處理方式。
策略模式: 將動態標簽處理方式抽象為介面,針對不同標簽有相應的實現類。解釋抽象語法樹時,定義統一的解釋流程,再調用標簽對應的處理方式完成解釋中的各個子環節
⑹ 請教Mybatis中如何在程序中獲取Mapper中定義的SQL語句
<mappernamespace="AccountMapper">
<updateid="updateLoginTime"parameterType="int">
<![CDATA[
updatesys_accountsetlogin_date=now(),updatedate=now()whereid=#{accountId}
]]>
</update>
</mapper>
舉例如上面的xml定義的Mapper,在代碼中可以通過AccountMapper.updateLoginTime獲取到update sys_account set login_date = now(), updatedate = now() where id = #{accountId}這行sql