本身動手搭建SSM

1.工具

  • apache-tomcat 7
  • apache-maven(後面詳細講!這東西我一開始也很懵逼)
  • mysql 5以上的版本
  • navicat(有了這個就不用cmd了,能夠直接顯示數據庫,以下圖,請自行百度綠色版QAQ)這裏寫圖片描述
  • IntelliJ IDEA 2016.3.4(http://www.jb51.net/softs/527945.html,根據鏈接教程慢慢安裝吧~)

2.前言

前不久學完了spring和mybatis基礎,因而決定來整合ssm。可是跟着學長的博客教程走的時候,出現了不少問題,因而打算轉載一下他的博客,並加上我本身的理解,來寫這麼一篇博客。那麼,請務必包含耐性,內容較多,慢慢來實現ssm的helloworld入門項目(原出處:http://blog.csdn.net/lxfhahaha/article/details/57078994css

3.步驟

1)準備工做

1.1 mysql數據庫安裝,此處直接引用學長的教程 
http://blog.csdn.net/lxfhahaha/article/details/56847353html

1.2 Tomcat安裝 
http://blog.csdn.net/zyf2333/article/details/77387649前端

1.3 maven安裝 
(安裝教程:https://jingyan.baidu.com/article/fd8044fadc1ac15031137a12.html) 
此處我是下載到D盤,而後本身在maven目錄下建立了一個repository文件夾(隨便取名)這裏寫圖片描述
而後打開conf文件夾下的settings.xml,在大約100行左右,修改圈中的目錄,此處目錄寫你剛剛建立的repository文件夾的目錄,如上圖中,個人repository目錄是 D:\maven\repository,那此處就改爲個人目錄(沒有<localRepository>的話就本身添加就是的了) 
這裏寫圖片描述
接下來在大約150行左右,在<mirrors> 元素之間添加以下代碼java

<mirror> <id>alimaven</id> <name>aliyun maven</name> <url>http://maven.aliyun.com/nexus/content/groups/public/</url> <mirrorOf>central</mirrorOf> </mirror> <mirror> <id>jboss-public-repository-group</id> <mirrorOf>central</mirrorOf> <name>JBoss Public Repository Group</name> <url>http://repository.jboss.org/nexus/content/groups/public</url> </mirror> <mirror> <id>alimaven</id> <mirrorOf>central</mirrorOf> <name>aliyun maven</name> <url>http://maven.aliyun.com/nexus/content/repositories/central/</url> </mirror>

最後效果以下 
這裏寫圖片描述mysql

1.3.1 maven是幹嗎的? 
答:百度上也有,說是管理jar包的。通俗點就是:若是你之前有過使用eclipse的經驗,就會知道,那麼當咱們須要引用外來jar包的時候,都會本身找jar包,而後下載並添加到項目運行環境中。而使用maven,則能夠自動下載,不用咱們本身去下載了。或者有時候咱們用eclipse導入spring支持的包時候,也須要本身添加所須要的jar包,運用maven就能夠自動添加了。 
1.3.2 建立repository文件夾幹嗎? 
答:這個文件夾是用來存放maven自動下載的jar包的。咱們第一次使用的時候,會進行下載,這樣會耗一點時間,之後咱們再用就直接用這個文件夾下的jar包了。 
1.3.3 爲何要修改setting.xml中的<localRepository> 
答:咱們上面說了,maven會下載jar包並存放到本身創好的repository文件夾下。這個操做就是設置讓maven把下載下來的jar包放入repository文件夾 
1.3.4 爲何要修改setting.xml中的<mirror> ? 
答:咱們說了,maven會自動下載。那麼它從哪一個網站下載呢?此處就要用到這個<mirror> 了。因爲maven默認的下載地址是國外的網站,可能因爲牆的緣由下載會超級超級慢。所以咱們自動添加幾個國內的網站,此處就用了阿里雲。能夠多添加幾個網站,由於有些網站可能jar包不是很全,所以多添加幾個以防萬一 
1.3.5 要是添加了好幾個網站後也沒有我想要的jar包呢? 
答:要麼再加幾個網站,要麼本身手動添加(方法後面講)web

1.4 自行安裝IDEA,這裏很少說了spring

2)建立maven項目

在建立以前,請自行在數據庫中建立名爲」example」的數據庫,裏面有個user表。以下: 
這裏寫圖片描述sql

這裏寫圖片描述

這裏寫圖片描述

點擊next,填寫對應的GroupId,ArtifactId(GroupId隨意填,我也不太知道有什麼用。ArtifactId就是你項目名) 
(PS:接下來不要糾結個人項目名稱,由於我是同時開一個helloworld2,而後又用到了我已經架構好了的helloworld項目) 
這裏寫圖片描述數據庫

點擊next,此處就用到maven了。 
這裏寫圖片描述
而後next,最後finish,而後慢慢等。剛剛開始建立項目的時候,IDEA要花點時間來建立項目,等一下就行了(ps:有點慢的,慢慢等) 
這裏寫圖片描述apache

建立完了後,原生態目錄應該以下(目錄說明:.idea和helloworld.iml不用管,也不要刪,是IDEA自己的配置文件;src就是咱們寫項目的地方了。pom.xml是用來配合maven的。咱們要用什麼jar包,寫在pom.xml中,d盤中的maven就會自動從<mirror> 中下載到repository文件夾中) 
這裏寫圖片描述

接着,執行以下操做: 
1. 在main的java文件夾上,鼠標右鍵,找到 make directory as,選擇Sources root 
2. 在main的resources文件夾上,鼠標右鍵,找到make directory as,選擇Resources root 
3. 在test的java文件夾上,鼠標右鍵,找到make directory as,選擇Test Sources root 
4. 在test的resources文件夾上,鼠標右鍵,找到make directory as,選擇Test Resources root

繼續修改目錄結構,增長一些文件夾及文件,這些都是等一下要用的到的 
1. src->main->java下新建package com,再新建package springmvc,這兩個對應咱們剛開始的groupid 
2. springmvc包下新建四個包,controller包用來放前臺url映射文件,dao用來放與數據庫的接口文件,entity用來放實體類文件,service用來放本身定義的接口 
3. applicationContext.xml是spring配置文件 
4. sqlmap文件夾裏面放實體與數據庫的映射文件 
5. generator.xml和generator.properties是mybatis的配置文件 
6. jdbc.properties是數據庫相關信息 
7. log4j.properties是日誌配置文件 
8. webapp下新建css、images等文件,用來放前端資源 
9. web-inf下新建views文件件,jsp文件就放這裏面了 
修改後目錄以下: 
這裏寫圖片描述 
(PS:此處有些人項目可能不會像我這樣是「樹枝狀」,而是變成了」com.springmvc.controller.dao.entity.service」。即包都擠在一塊兒去了。解決方案:如圖,把劃線部分勾掉就行了) 
這裏寫圖片描述

3)項目配置文件

3.一、配置pom.xml文件,引入所須要的jar包

以前說了,pom.xml是用來配合maven使用的,咱們想要什麼jar包,直接在pom.xml中寫出來,maven就會自動幫咱們下載。當你剛剛開始用maven時候,repository文件夾裏面仍是空的,所以要花時間來下載,請直接把接下來的代碼複製黏貼。在這裏,咱們只須要關注<dependency>標籤就行了
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.springtest</groupId> <artifactId>helloworld</artifactId> <packaging>war</packaging> <version>1.0-SNAPSHOT</version> <name>helloworld Maven Webapp</name> <url>http://maven.apache.org</url> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>3.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>3.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>3.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>3.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>3.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>3.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>3.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>3.1.1.RELEASE</version> </dependency> <!-- springframe end --> <!-- mybatis核心包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.3.1</version> </dependency> <!-- mybatis/spring包 --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>1.2.2</version> </dependency> <!-- mysql驅動包 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.29</version> </dependency> <!-- junit測試包 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> <!-- jstl --> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.2.1-b03</version> <scope>provided</scope> </dependency> <!-- servlet --> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> <!-- json數據 --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.8.5</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.8.5</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> <version>2.8.5</version> </dependency> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.4</version> </dependency> <dependency> <groupId>net.sf.json-lib</groupId> <artifactId>json-lib</artifactId> <version>2.4</version> <classifier>jdk15</classifier> </dependency> <!-- commons --> <dependency> <groupId>commons-lang</groupId> <artifactId>commons-lang</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> <version>1.1</version> </dependency> <dependency> <groupId>commons-pool</groupId> <artifactId>commons-pool</artifactId> <version>1.5.6</version> </dependency> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency> <dependency> <groupId>commons-beanutils</groupId> <artifactId>commons-beanutils</artifactId> <version>1.8.3</version> </dependency> <dependency> <groupId>commons-httpclient</groupId> <artifactId>commons-httpclient</artifactId> <version>3.1</version> </dependency> <dependency> <groupId>commons-collections</groupId> <artifactId>commons-collections</artifactId> <version>3.1</version> </dependency> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.9</version> </dependency> <dependency> <groupId>javax.annotation</groupId> <artifactId>jsr250-api</artifactId> <version>1.0</version> </dependency> <dependency> <groupId>net.sf.ezmorph</groupId> <artifactId>ezmorph</artifactId> <version>1.0.6</version> </dependency> <dependency> <groupId>javax.activation</groupId> <artifactId>activation</artifactId> <version>1.1</version> </dependency> <dependency> <groupId>taglibs</groupId> <artifactId>standard</artifactId> <version>1.1.2</version> </dependency> <!-- 日誌文件管理包 --> <!-- log start --> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.5</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.7.21</version> </dependency> </dependencies> <build> <finalName>helloworld</finalName> <plugins> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.2</version> <configuration> <!--容許移動生成的文件--> <verbose>true</verbose> <!--容許覆蓋生成的文件--> <overwrite>true</overwrite> </configuration> </plugin> </plugins> </build> </project> 

 

3.二、jdbc.properties

driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/example?useUnicode=true&characterEncoding=utf-8 username=root #下面輸入本身數據庫的密碼 password=輸入本身數據庫的密碼吧 #定義初始鏈接數 initialSize=0 #定義最大鏈接數 maxActive=20 #定義最大空閒 maxIdle=20 #定義最小空閒 minIdle=1 #定義最長等待時間 maxWait=60000

 

3.三、applicationContext.xml(配置spring)

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:beans="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd" > <!-- ①:對com.springmvc包中的全部類進行掃描,以完成Bean建立和自動依賴注入的功能 --> <context:component-scan base-package="com.springmvc"/> <mvc:annotation-driven /> <!-- 靜態資源訪問 --> <!--若是webapp下你新建了文件夾,想訪問裏面的靜態資源,那麼就要在這配置一下--> <mvc:resources location="/images/" mapping="/images/**"/> <mvc:resources location="/css/" mapping="/css/**"/> <mvc:resources location="/styles/" mapping="/styles/**"/> <mvc:resources location="/js/" mapping="/js/**"/> <!-- Configures the @Controller programming model <mvc:annotation-driven />--> <!-- ②:啓動Spring MVC的註解功能,完成請求和註解POJO的映射 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"> <property name="messageConverters"> <list> <ref bean="mappingJacksonHttpMessageConverter"/> </list> </property> </bean> <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>application/json;charset=UTF-8</value> </list> </property> </bean> <!-- 配置視圖解析器,把控制器的邏輯視頻映射爲真正的視圖 --> <!-- /WEB-INF/jsp/start.jsp --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> <!-- 配置dbcp數據庫鏈接池 --> <!-- <context:property-placeholder location="classpath:db.properties"/> --> <!--數據庫配置 --> <bean id = "propertyConfigurer" class = "org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:jdbc.properties</value> </list> </property> </bean> <!-- 數據庫鏈接池 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <property name="initialSize" value="1"/> <property name="maxActive" value="100"/> <property name="maxIdle" value="5"/> <property name="maxWait" value="80000"/> </bean> <!-- 配置事務管理器 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!-- 攔截器 --> <mvc:interceptors> <!-- 國際化操做攔截器 若是採用基於(請求/Session/Cookie)則必需配置 --> <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" /> </mvc:interceptors> <!-- 定義無Controller的path<->view直接映射 --> <mvc:view-controller path="/" view-name="redirect:/" /> <!-- 配置會話工廠SqlSessionFactory --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 數據源 --> <property name="dataSource" ref="dataSource"/> <property name="mapperLocations" value="classpath:sqlmap/*Mapper.xml"/> <property name="typeAliasesPackage" value="com.springmvc.entity" /> </bean> <!-- 在spring容器中配置mapper的掃描器產生的動態代理對象在spring的容器中自動註冊,bean的id就是mapper類名(首字母小寫)--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!-- 指定掃描包的路徑,就是mapper接口的路徑,多個包中間以 半角逗號隔開 --> <property name="basePackage" value="com.springmvc.dao"/> <!-- 配置sqlSessionFactoryBeanName --> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> </bean> </beans>

 

3.四、log4j.properties

### set log levels ### log4j.rootLogger = INFO,D ###輸出到控制檯### log4j.logger.toConsole=debug,stdout log4j.appender.stdout = org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target = System.out log4j.appender.stdout.layout = org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern =%d{yyyy-MM-dd HH\:mm\:ss} [%5p] - %c -%F(%L) -%m%n ### 輸出到日誌文件 ### ## 其中File 能夠採用絕對路徑 亦能夠採用相對路徑 catalina.home 是tomcat目錄 若是沒有logs文件夾 將會報錯 ## ## 更加傾向於將日誌文件放在 tomcat的日誌目錄下${catalina.home}/logs/salesmanb2bError.log ## ## 絕對路徑如:e:/salesmanb2bError.log ## log4j.logger.daily=INFO,D log4j.appender.D = org.apache.log4j.DailyRollingFileAppender log4j.appender.D.File = ${catalina.home}/logs/helloworld/helloworld.log log4j.appender.D.Append = true log4j.appender.D.Threshold = INFO log4j.appender.D.layout = org.apache.log4j.PatternLayout log4j.appender.D.layout.ConversionPattern =%d{yyyy-MM-dd HH\:mm\:ss} [%5p] - %c -%F(%L) -%m%n ##log4j.logger.org.apache.ibatis=debug,stdout ##log4j.logger.java.sql=debug,stdout

3.五、web.xml(在WEB-INF下)

<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> <display-name>helloworld</display-name> <!-- 配置編碼方式--> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- 配置springmvc的前端控制器 指向spring-mvc.xml 程序在啓動的時候就加載springmvc 能夠接受全部請求 load-on-startup:表示啓動容器時初始化該Servlet; --> <servlet> <servlet-name>springServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 能夠自定義servlet.xml配置文件的位置和名稱, 默認爲WEB-INF目錄下,名稱爲[<servlet-name>]-servlet.xml,如spring-servlet.xml --> <init-param> <param-name>contextConfigLocation</param-name> <param-value> classpath:spring/applicationContext.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!-- 將前端URL請求和後臺處理方法controller創建對應關係--> <servlet-mapping> <servlet-name>springServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!-- Spring配置 --> <listener> <listener-class> org.springframework.web.context.ContextLoaderListener </listener-class> </listener> <!-- 取消對某一類文件的攔截--> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.md</url-pattern> </servlet-mapping> <context-param> <param-name>contextConfigLocation</param-name> <param-value> classpath:spring/applicationContext.xml</param-value> </context-param> <!-- 歡迎頁面--> <welcome-file-list> <welcome-file>/WEB-INF/views/index.jsp</welcome-file> </welcome-file-list> <!--404錯誤展現頁面,可自行配置--> <!--<error-page>--> <!--<error-code>404</error-code>--> <!--<location>/WEB-INF/views/404.jsp</location>--> <!--</error-page>--> <!--設置session失效時間爲30分鐘 --> <session-config> <session-timeout>600</session-timeout> </session-config> </web-app>

 

3.六、在WEB-INF/views/下建立index.jsp。本身隨便寫點啥東西

4)配置Tomcat

點擊如圖所示區域,進入「Edit Configurations」 
這裏寫圖片描述
這裏寫圖片描述

進入設置後,先點擊「1」選擇設置Tomcat,而後點擊「2」選擇本地Tomcat所在,最後點擊「3」生效 
這裏寫圖片描述
而後將項目部署到Tomcat中,如圖(ps:第二步以後選擇Artifact選項) 
這裏寫圖片描述
返回來,將如圖的」do nothing」改爲「update…」 
這裏寫圖片描述
運行 
這裏寫圖片描述

5)mybatis generator配置

在applicationContext.xml中添加以下代碼

<!-- 配置會話工廠SqlSessionFactory --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 數據源 --> <property name="dataSource" ref="dataSource"/> <property name="mapperLocations" value="classpath:sqlmap/*Mapper.xml"/> <property name="typeAliasesPackage" value="com.springmvc.entity" /> </bean> <!-- 在spring容器中配置mapper的掃描器產生的動態代理對象在spring的容器中自動註冊,bean的id就是mapper類名(首字母小寫)--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!-- 指定掃描包的路徑,就是mapper接口的路徑,多個包中間以 半角逗號隔開 --> <property name="basePackage" value="com.springmvc.dao"/> <!-- 配置sqlSessionFactoryBeanName --> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> </bean>

 

 

generatorConfig.xml(ps:一、 「http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd「該xml中這句話可能紅色報錯,不用管的。二、第9行的location=」D:\maven\repository\mysql\mysql-connector-java\5.1.29\mysql-connector-java-5.1.29.jar」 是你本身的mysql.jar所在的位置,必定要填寫對應的位置,否則就會報錯。若是你以前是跟着個人存放目錄走的話,應該就是這個路徑的)

<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> <generatorConfiguration> <!--導入屬性配置 --> <properties resource="generator.properties"/> <classPathEntry location="D:\maven\repository\mysql\mysql-connector-java\5.1.29\mysql-connector-java-5.1.29.jar" /> <context id="context1"> <!-- 註釋 --> <commentGenerator> <property name="suppressAllComments" value="true" /><!-- 是否取消註釋 --> <property name="suppressDate" value="true" /> <!-- 是否生成註釋代時間戳 --> </commentGenerator> <jdbcConnection driverClass="${driver}" connectionURL="${url}" userId="${username}" password="${password}" /> <!-- 類型轉換 --> <javaTypeResolver> <!-- 是否使用bigDecimal, false可自動轉化如下類型(Long, Integer, Short, etc.) --> <property name="forceBigDecimals" value="false" /> </javaTypeResolver> <javaModelGenerator targetPackage="${modelPackage}" targetProject="${modelProject}" /> <sqlMapGenerator targetPackage="${sqlPackage}" targetProject="${sqlProject}" /> <javaClientGenerator targetPackage="${mapperPackage}" targetProject="${mapperProject}" type="XMLMAPPER" /> <!-- 若是須要通配全部表 直接用sql的通配符 %便可 --> <table schema="" tableName="${table}" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"/> </context> </generatorConfiguration>

 

generator.properties 
說明:以前已經建立了一個example數據庫,裏面有個數據表user(第二大步「建立maven項目」下面)。而後modelPackage是等會鏈接數據庫自動生成的實體類保存的位置,sqlPackage是生成xml映射文件保存的位置,mapperPackage是生成數據庫接口保存的位置,table是數據庫裏面的表的名字

driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/example?useUnicode=true&characterEncoding=utf-8 username=root password=************* #entity 包名和 java目錄 modelPackage=com.springmvc.entity modelProject=src/main/java #sqlmap包名 和resources目錄 sqlPackage=sqlmap sqlProject=src/main/resources #mapper包名和 java目錄 mapperPackage=com.springmvc.dao mapperProject=src/main/java table=user

 

配置完成,雙擊圈中的地方(ps:要是沒有像我同樣的maven目錄,則按照以下步驟顯示:「View->Tool Windows->Maven Project」便可顯示出來) 
這裏寫圖片描述

因而會自動建立圖中三個文件 
這裏寫圖片描述

進入UserMapper.java。在接口上方添加@Repository註釋,而後將鼠標放到public interface UserMapper處,點擊alt+enter鍵,接着點擊create test 
這裏寫圖片描述
勾選insert 
這裏寫圖片描述 
因而IDEA會自動幫咱們建立個測試類 
這裏寫圖片描述
代碼以下

package com.springmvc.dao; import com.springmvc.entity.User; import org.junit.After; import org.junit.Before; import org.junit.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import static org.junit.Assert.*; /** * Created by 11655 on 2017/3/11. */ public class UserMapperTest { private ApplicationContext applicationContext; @Autowired private UserMapper userMapper; @Before public void setUp() throws Exception { applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");//加載spring配置文件 userMapper = applicationContext.getBean(UserMapper.class);//在這裏導入要測試的 } @After public void tearDown() throws Exception { } @Test public void insert() throws Exception { User user = new User(); user.setId(12); int result = userMapper.insertSelective(user); System.out.println(result); assert (result == 1); } }

 

而後點擊圖中有個小感嘆號的地方,選擇」run insert()」 
這裏寫圖片描述
這裏寫圖片描述
這裏寫圖片描述 到此,ssm入門整合結束

相關文章
相關標籤/搜索