1. 如何編寫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:使用一個結果值為了決定使用哪個結果集。
2. mybatis的sql映射文件可以放在什麼包里
mapper包里,和對應的mapper介面放一起
3. MyBatis sql映射文件疑問
其實沒有什麼區別,只不過是取值的方式不一樣罷了,
<resultMap id="wpResult" class="wp">
</resultMap>
配了一次就可以反復用,
Alias 需要在查詢語句里一個一個的as,你不覺得麻煩也可以用。
Alias最大的作用是聯表查詢的時候返回多個相同ID的時候可以改下名。不致於沖突報錯
4. MyBatis之SQL語句映射文件增刪改查和Java參數如何對應
insert可以使用資料庫支持的自動生成主鍵策略,設置useGeneratedKeys=」true」,然後把keyProperty 設成對應的列,就搞定了。
比如說上面的StudentEntity 使用auto-generated 為id 列生成主鍵.
還可以使用selectKey元素。
使用mysql資料庫nextval('student')為自定義函數,用來生成一個key。
5. mybatis原理
MyBatis 的工作原理:讀取 MyBatis 配置文件、載入映射文件、構造會話工廠、創建會話對象、Executor 執行器、輸入參數映射、輸出結果映射。
mybatis原理具體介紹如下:
1、讀取 MyBatis 配置文件:
mybatis-config.xml 為 MyBatis 的全局配置文件,配置了 MyBatis 的運行環境等信息,例如資料庫連接信息。
2、載入映射文件:
映射文件即 SQL 映射文件,該文件中配置了操作資料庫的 SQL 語句,需要在 MyBatis 配置文件 mybatis-config.xml 中載入。mybatis-config.xml 文件可以載入多個映射文件,每個文件對應資料庫中的一張表。
3、構造會話工廠:
通過 MyBatis 的環境等配置信息構建會話工廠 SqlSessionFactory。
4、創建會話對象:
由會話工廠創建 SqlSession 對象,該對象中包含了執行 SQL 語句的所有方法。
5、Executor 執行器:
MyBatis 底層定義了一個 Executor 介面來操作資料庫,它將根據 SqlSession 傳遞的參數動態地生成需要執行的 SQL 語句,同時負責查詢緩存的維護。
8、輸出結果映射:
輸出結果類型可以是 Map、 List 等集合類型,也可以是基本數據類型和 POJO 類型。輸出結果映射過程類似於 JDBC 對結果集的解析過程。
6. mybatis是如何將sql執行結果封裝為目標對象並返回的都有哪些映射形式
是寫一個resultmap然後指明欄位和屬性映射關系就行