java mybatis入门笔记

一、mybatis工具

可使用mybatis-generator-core工具生成实体类、映射文件以及持久层接口;

http://blog.csdn.net/isea533/article/details/42102297  对如何定义mybatis-generator-core配置文件进行了比较详细的说明

二、学习地址

http://www.yiibai.com/mybatis/install_configure.html#article-start

三、mybatis与spring的整合

1)web.xml整合

<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xmlns="http://java.sun.com/xml/ns/javaee" 
         xmlns:web="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>Archetype Created Web Application</display-name>
      <!-- Spring监听器 -->  
    <listener>  
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
    </listener>     
    <context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>/WEB-INF/root-content.xml</param-value>
    </context-param>	
    <!-- 防止Spring内存溢出监听器-->  
    <listener>  
        <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>  
    </listener>             
           
   <!-- Spring和mybatis的配置文件 -->  
    <context-param>  
        <param-name>contextConfigLocation</param-name>  
        <param-value>classpath:spring-mybatis.xml</param-value>  
    </context-param>

    <!-- 编码过滤器 -->
    <filter>  
        <filter-name>encodingFilter</filter-name>  
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  
        <async-supported>true</async-supported>  
        <init-param>  
            <param-name>encoding</param-name>  
            <param-value>UTF-8</param-value>  
        </init-param>  
    </filter>  
    <filter-mapping>  
        <filter-name>encodingFilter</filter-name>  
        <url-pattern>/*</url-pattern>  
    </filter-mapping>  
 
  
    <!-- Spring MVC servlet -->  
    <servlet>  
        <servlet-name>SpringMVC</servlet-name>  
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
        <init-param>  
            <param-name>contextConfigLocation</param-name>  
            <param-value>classpath:spring-mvc.xml</param-value>  
        </init-param>  
        <load-on-startup>1</load-on-startup>  
        <async-supported>true</async-supported>
    </servlet>  
    <servlet-mapping>  
        <servlet-name>SpringMVC</servlet-name>  
        <!-- 此处可以配置成*.do,对应struts的后缀习惯 -->  
        <url-pattern>/</url-pattern>  
    </servlet-mapping>  

	<welcome-file-list>  
        <welcome-file>/index.jsp</welcome-file>  
    </welcome-file-list>    
    
</web-app>
特别说明:web.xml配置文件装载有顺序,需要首先定义ContextLoaderListener,然后导入mybatis配置文件,再导入mvc配置文件,否则编程使用 @Autowired   SUserMapper userMapper;由mybatis实现相应的dao层接口时会提示没有bean的错误;具体原因还待研究。
2)、jdbc.properties配置,分别举例说明mysql、sqlserver、oracle三种数据库连接配置信息

mysql:

<jdbcConnection password="root" userId="root" connectionURL="jdbc:mysql://localhost:3306/solidbase_db" driverClass="com.mysql.jdbc.Driver"> </jdbcConnection>
sqlserver

driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
url=jdbc:sqlserver://localhost:1433;DatabaseName=WorkCheck
user=sa
password=123456
oracle

<jdbcConnection password="list" userId="lzhd" connectionURL="jdbc:oracle:thin:@127.0.0.1:1521:orcl" driverClass="oracle.jdbc.driver.OracleDriver"> </jdbcConnection>
3、mybatis.xml  该配置整合了数据库连接配置、映射文件配置等多种配置信息

<?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:p="http://www.springframework.org/schema/p"  
        xmlns:context="http://www.springframework.org/schema/context"  
        xmlns:mvc="http://www.springframework.org/schema/mvc"  
        xsi:schemaLocation="http://www.springframework.org/schema/beans    
                            http://www.springframework.org/schema/beans/spring-beans-3.1.xsd    
                            http://www.springframework.org/schema/context    
                            http://www.springframework.org/schema/context/spring-context-3.1.xsd    
                            http://www.springframework.org/schema/mvc    
                            http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">  
        <!-- 自动扫描 -->          
       <context:component-scan base-package="com.springmvc.entity" />         
       <!-- 引入配置文件 -->  
       <bean id="propertyConfigurer"  
            class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
            <property name="location" value="classpath:jdbc.properties" />  
        </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="${user}" />  
            <property name="password" value="${password}" />             
        </bean>                
        <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->  
        <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
            <property name="dataSource" ref="dataSource" />  
            <!-- 自动扫描mapping.xml文件 -->  
            <property name="mapperLocations" value="classpath:com/springmvc/dao/*.xml"></property>  
        </bean>        
        <!-- DAO接口所在包名,Spring会自动查找其下的类 -->  
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
            <property name="basePackage" value="com.springmvc.dao" />  
            <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>  
        </bean>        
        <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->  
        <bean id="transactionManager"  
            class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
            <property name="dataSource" ref="dataSource" />  
        </bean>              
    </beans>  
4、spring-mvc配置文件

<?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:p="http://www.springframework.org/schema/p"  
        xmlns:context="http://www.springframework.org/schema/context"  
        xmlns:mvc="http://www.springframework.org/schema/mvc"  
        xsi:schemaLocation="http://www.springframework.org/schema/beans    
                            http://www.springframework.org/schema/beans/spring-beans-3.1.xsd    
                            http://www.springframework.org/schema/context    
                            http://www.springframework.org/schema/context/spring-context-3.1.xsd    
                            http://www.springframework.org/schema/mvc    
                            http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">  
        <!-- 自动扫描该包,使SpringMVC认为包下用了@controller注解的类是控制器 -->  
        <context:component-scan base-package="com.springmvc.controller" />  
        <context:annotation-config/>
        <mvc:annotation-driven/> 
        
        <!-- 服务器上的静态资源需要映射为相对路径后调用访问 --> 
        <mvc:resources location="/WEB-INF/statics/javascript/" mapping="/js/**"/>
        <mvc:resources location="/WEB-INF/css/" mapping="/css/**"/>
        <mvc:resources location="/WEB-INF/image/" mapping="/image/**"/>
         
        <!--避免IE执行AJAX时,返回JSON出现下载文件 -->  
        <!-- 
        <bean id="mappingJacksonHttpMessageConverter"  
            class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">  
            <property name="supportedMediaTypes">  
                <list>  
                    <value>text/html;charset=UTF-8</value>  
                </list>  
            </property>  
        </bean>
          -->
        <!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 -->  
        <!-- 
        <bean  
            class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">  
            <property name="messageConverters">  
                <list>  
                    <ref bean="mappingJacksonHttpMessageConverter" />                                        
                </list>  
            </property>  
        </bean> 
        -->
        
        <!-- 定义跳转的文件的前后缀 ,视图模式配置(对应控制的访问返回给jsp页面),当需要返回rss订阅信息或返回xml时更改响应的bean配置-->  
        <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">  
            <!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 -->  
            <property name="prefix" value="/WEB-INF/pages/" />  
            <property name="suffix" value=".jsp" />  
        </bean>  
          
        <!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 -->
         <!-- 
        <bean id="multipartResolver"    
            class="org.springframework.web.multipart.commons.CommonsMultipartResolver">                
            <property name="defaultEncoding" value="utf-8" />               
            <property name="maxUploadSize" value="10485760000" />              
            <property name="maxInMemorySize" value="40960" />  
        </bean>     
         -->
    </beans>  

5、spring 注释

spring  bean注释有@Repository、@Service、@Controller,需要使用spring-aop包,在类上使用@Component注解,表示该类定义为Spring管理Bean,使用默认value(可选)属性表示Bean标识符。如果不指定标识符,默认为首字母小写类名。例如类UserController的标识符为userController。通过在xml文件中配置扫描策略,指定由spring进行加载;


<context:component-scan
2         base-package=""
3         resource-pattern="**/*.class"
4         name-generator="org.springframework.context.annotation.AnnotationBeanNameGenerator"
5         use-default-filters="true"
6         annotation-config="true">
7                 <context:include-filter type="aspectj" expression=""/>
8                 <context:exclude-filter type="regex" expression=""/>
9 </context:component-scan>
属性定义如下:

  • base-package:表示扫描注解类的开始位置,即将在指定的包中扫描,其他包中的注解类将不被扫描,默认将扫描所有类路径;

  • resource-pattern:表示扫描注解类的后缀匹配模式,即“base-package+resource-pattern”将组成匹配模式用于匹配类路径中的组件,默认后缀为“**/*.class”,即指定包下的所有以.class结尾的类文件;

  • name-generator:默认情况下的Bean标识符生成策略,默认是AnnotationBeanNameGenerator,其将生成以小写开头的类名(不包括包名);可以自定义自己的标识符生成策略;

  • use-default-filters:默认为true表示过滤@Component、@ManagedBean、@Named注解的类,如果改为false默认将不过滤这些默认的注解来定义Bean,即这些注解类不能被过滤到,即不能通过这些注解进行Bean定义;

  • annotation-config:表示是否自动支持注解实现Bean依赖注入,默认支持,如果设置为false,将关闭支持注解的依赖注入,需要通过<context:annotation-config/>开启。

  • <context:include-filter>:表示过滤到的类将被注册为Spring管理Bean。需要配合use-default-filters使用

  • <context:exclude-filter>:表示过滤到的类将不被注册为Spring管理Bean,它比<context:include-filter>具有更高优先级;

  • type:表示过滤器类型,目前支持注解类型、类类型、正则表达式、aspectj表达式过滤器,当然也可以自定义自己的过滤器,实现org.springframework.core.type.filter.TypeFilter即可;

  • expression:表示过滤器表达式。

各类属性示例参见博文:http://www.cnblogs.com/caoyc/p/5625920.html


@Autowired 注释,它可以对类成员变量、方法及构造函数进行标注,完成自动装配的工作。 通过 @Autowired的使用来消除 set ,get方法。

@Repository用于标记数据访问组件,即DAO组件

@Repository注解的POJO类表示DAO层实现,从而见到该注解就想到DAO层实现,使用方式和@Component相同;

@Repository  
public class VentorDaoImpl implements iVentorDao {   
} 

通过@Component将切面定义为Spring管理Bean。

@Service

@Component扩展,被@Service注解的POJO类表示Service层实现,从而见到该注解就想到Service层实现,使用方式和@Component相同;

@Controller

@Component扩展,被@Controller注解的类表示Web层实现,从而见到该注解就想到Web层实现,使用方式和@Component相同;







猜你喜欢

转载自blog.csdn.net/u012846041/article/details/79082453