一、Spring在ssm中起到什麼做用?前端
Spring:輕量級框架java
做用:Bean工廠,用來管理Bean的生命週期和框架集成。spring
兩大核心:sql
①. IOC/DI(控制反轉/依賴注入) :把dao依賴注入到service層,service層反轉給action層,Spring頂層容器爲BeanFactory。數據庫
②. AOP:面向切面編程apache
二、spring事務是什麼?編程
編程式事務管理:編程方式管理事務,極大靈活性,難維護。json
聲明式事務管理:能夠將業務代碼和事務管理分離,用註解和xml配置來管理事務。安全
三、IOC在項目中的做用?mybatis
做用:Ioc解決對象之間的依賴問題,把全部Bean的依賴關係經過配置文件或註解關聯起來,下降了耦合度。
四、Spring的配置文件中的內容?
開啓事務註解驅動
事務管理器
開啓註解功能,並配置掃描包
配置數據庫
配置SQL會話工廠,別名,映射文件
不用編寫Dao層的實現類
五、Spring下的註解?
註冊:@Controller @Service @Component
注入:@Autowired @Resource
請求地址:@RequestMapping
返回具體數據類型而非跳轉:@ResponseBody
六、SpringDI的三種方式?
構造器注入:經過構造方法初始化
<constructor-arg index="0" type="java.lang.String" value="寶馬"></constructor-arg>
setter方法注入:經過setter方法初始化
<property name="id" value="1111"></property>
接口注入
七、Spring主要使用了什麼模式?
工廠模式:每一個Bean的建立經過方法
單例模式:默認的每一個Bean的做用域都是單例
代理模式:關於Aop的實現經過代理模式
八、IOC、AOP的實現原理?
IOC:經過反射機制生成對象注入
AOP:動態代理
問題:單例模式,在多線程訪問時有線程安全問題
解決方法:不要用同步,在控制器裏面不能寫字段
@Controller:該註解代表該類扮演控制器的角色
做用:用來映射一個URL到一個類或者一個特定的處理方法上
方法:直接在方法中聲明這個對象,SpringMvc就自動把屬性賦值到這個對象裏面
String,ModelAndView,List,Set 等
通常String,Ajax請求,返回一個List集合
轉發: return:「hello」
重定向 :return:「redirect:hello.jsp」
經過JackSon框架把java裏面對象直接轉換成js可識別的json對象,具體步驟以下:
加入JackSon.jar
在配置文件中配置json的映射
在接受Ajax方法裏面直接返回Object,list等,方法前面須要加上註解@ResponseBody
入口不一樣:
Struts2:filter過濾器
SpringMvc:一個Servlet即前端控制器
開發方式不一樣:
Struts2:基於類開發,傳遞參數經過類的屬性,只能設置爲多例
SpringMvc:基於方法開發(一個url對應一個方法),請求參數傳遞到方法形參,能夠爲單例也能夠爲多例(建議單例)
請求方式不一樣:
Struts2:值棧村塾請求和響應的數據,經過OGNL存取數據
SpringMvc:經過參數解析器將request請求內容解析,給方法形參賦值,將數據和視圖封裝成ModelAndView對象,最後又將ModelAndView中的模型數據經過request域傳輸到頁面,jsp視圖解析器默認使用的是jstl。
Ibatis:2010年,apache的Ibatis框架中止更新,並移交給了google團隊,同時改名爲MyBatis。從2010年後Ibatis在沒更新過,完全變成了一個孤兒框架。一個沒人維護的框架註定被mybatis拍在沙灘上。
Mybatis實現了DAO接口與xml映射文件的綁定,自動爲咱們生成接口的具體實現,使用起來變得更加省事和方便。
註解使用狀況:Sql語句簡單時
xml綁定使用狀況:xml綁定 (@RequestMap用來綁定xml文件)
SqlSession
映射鍵值對便可
<result column="title" property="title" javaType="java.lang.String"/>
column:數據庫中表的列名
property:實體Bean中的屬性名
把Sql語句從Java中獨立出來。
封裝了底層的JDBC,API的調用,而且可以將結果集自動轉換成JavaBean對象,簡化了Java數據庫編程的重複工做。
本身編寫Sql語句,更加的靈活。
入參無需用對象封裝(或者map封裝),使用@Param註解
<collection property="topicComment" column="id" ofType="com.tmf.bbs.pojo.Comment" select="selectComment" />
property:屬性名
column:共同列
ofType:集合中元素的類型
select:要鏈接的查詢
<association property="topicType" select="selectType" column="topics_type_id" javaType="com.tmf.bbs.pojo.Type"/>
property:屬性名
select:要鏈接的查詢
column:共同列
javaType:集合中元素的類型
${}:簡單字符串替換,把${}直接替換成變量的值,不作任何轉換,這種是取值之後再去編譯SQL語句。
#{}:預編譯處理,sql中的#{}替換成?,補全預編譯語句,有效的防止Sql語句注入,這種取值是編譯好SQL語句再取值。
總結:通常用#{}來進行列的代替
select last _insert_id()
RowBounds對象分頁
在Sql內直接書寫,帶有物理分頁
經過SqlSessionFactoryBuilder從mybatis-config.xml配置文件中構建出SqlSessionFactory。
SqlSessionFactory開啓一個SqlSession,經過SqlSession實例得到Mapper對象而且運行Mapper映射的Sql語句。
完成數據庫的CRUD操做和事務提交,關閉SqlSession。