-
ooo查看全部
-
否則根據原字符串動態加載class查看全部
-
大小寫都可以,并且不用寫包名.類名,建議寫查看全部
-
XML的解析查看全部
-
的點點滴滴查看全部
-
將配置文件中的<congfiguration>節點傳遞給XMLConfigBuilder的parseConfiguration(XNode)方法來解析,截圖是parseConfiguration解析mybatis配置文件的全過程,閱讀源碼的方式遞歸閱讀。查看全部
-
MYSQL 批量插入語句查看全部
-
攔截器實現3 過濾客戶 ----- id.matches(".+ByPage$") 獲取購票信息 ----- page 購票 ----- 原始sql-->pageSql 送票 ----- return invocation.proceed();查看全部
-
實現攔截器需要實現三個方法:①intercept(Invocation invacation) ② plugin(Object target)方法參數就是被攔截的對象target,返回的就是滿足條件的代理類,Plugin.wrap(target,this):this也就是自定義攔截器實例,通過獲取注解得到要攔截的類型,比較target的類型與this獲取的要攔截的類型是不是一致,如果滿足條件就獲取代理對象,并執行intercept方法,沒有獲取代理對象的將直接返回,不會經過intercept方法。 mybatis獲取statement其實是在statementHandler中,這是一個處理接口,有個prepare方法,返回Statement,這個方法是在BaseStatementHandler中實現的,statement是在instantiateStatement這個方法中獲取的,這個方法是一個抽象方法,看它的PrepareStatementHandler實現,在這里邊看到了connection.prepareStatement(sql,PreparedStatement.),也就是和JDBC類似的代碼了,這就是分頁攔截器要攔截的位置了。如何實現攔截呢?mybatis提供了相應的注解:@Intercept({@Signnature(type=StatementHandler.class),method=“prepare”,args={Connection.class}}) ①type指向要連接的接口class,這里指向StatementHandler.class, ②Method指向要攔截的方法,這里是prepare ③args[]攔截的方法的參數類型,這里是Connection.class 這樣就準確描述了要攔截StatementHandler接口下的prepare方法。目標確定,接下來就可以做手腳了,在PrepareStatementHandler拿到sql語句之前將這個sql語句改裝成我們的分頁sql,然后在塞回去,讓程序繼續執行,這樣就成功了。查看全部
-
過早過遲攔截都不合適查看全部
-
代購與攔截器 <select id="queryMessageList" parameterType="com.imooc.bean.Message" resultMap="MessageResult"> select <include refid="columns"/> from message <where> <if test="command!=null and !"".equals(command.trim())"> and COMMAND=#{command} </if> </where> </select> //對比上下代碼 <select id="queryMessageList" parameterType="java.util.Map" resultMap="MessageResult"> select <include refid="columns"/> from message <where> <if test="message.command!=null and !"".equals(message.command.trim())"> and COMMAND=#{message.command} </if> </where> order by ID limit #{page.dbIndex},#{page.dbNumber} </select> Q1:為何選擇java.util.Map?不用實體類? 因為里面代碼涉及到兩個實體類,所以選擇一個它們通用的類型。 Q2:為何選擇java.util.Map?不用Lits等之類的? 從parameterType來看字面意思是:參數類型,所以如下代碼: parameter.put("message", message); parameter.put("page", page); 傳過來的參數parameter來使用。所以接下來的屬性前加上message.xxx;page.xxx;(key值對應)。 注意:過早過遲的攔截都不合適。所以在PreparedStatement pstmt=conn.prepareStatement(sql.toString());之前攔截即可(把SQL語句處理再放進去提交)。查看全部
-
代理的作用查看全部
-
分頁功能查看全部
-
分頁一般按照某個字段排序,一般是主鍵,修改時間等 前端校驗等于沒有校驗,為了保證安全,最好后端做校驗。查看全部
-
與數據庫無關的類放到entity包里,與數據庫有關的放bean里查看全部
舉報
0/150
提交
取消