Spring与Ibatis整合教程

需积分: 3 13 下载量 141 浏览量 更新于2024-07-28 1 收藏 732KB PPT 举报
"Ibatis整合技术,Spring对Ibatis支持,Struts+Spring+Ibatis整合" Ibatis,原名MyBatis,是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。Ibatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。Ibatis可以被看作是一个半自动的ORM(对象关系映射)框架,它能让你能使用SQL来编写你的存储逻辑,同时又不失去手动控制什么时候调用SQL的能力。 在Ibatis中,`ParameterMap`和`ResultMap`是两个重要的概念。`ParameterMap`用于定义参数的映射关系,它可以映射多个参数到SQL语句中。而`ResultMap`则是用来映射查询结果到Java对象的,可以根据字段与Java对象的属性进行一一对应。在添加数据时,`#{}`中的属性通常代表参数对象的属性名,用于SpEL(Spring Expression Language)表达式解析,确保参数安全并防止SQL注入。 在进行模糊查询时,`$`符号用于动态SQL,它允许直接将字符串插入到SQL语句中,但这种方式可能会引发SQL注入问题,因为它不进行任何预编译或参数绑定。相比之下,`#{}`则会进行预编译,更加安全。 Spring对Ibatis的整合提供了强大的支持。Spring作为一个轻量级的IoC(Inversion of Control,控制反转)容器,不仅能够管理各种类型的bean,还可以管理和集成各种持久层框架,包括Ibatis。Spring提供了`DriverManagerDataSource`类来管理数据源,这是一个简单的数据源实现,适合于测试和小型应用。通过Spring的IoC容器,可以方便地管理和注入`SqlMapClient`。 `SqlMapClientFactoryBean`是Spring用来创建和管理`SqlMapClient`的工厂Bean,使得`SqlMapClient`可以通过IoC容器进行依赖注入。此外,`SqlMapClientDaoSupport`和`SqlMapClientTemplate`类提供了方便的DAO(Data Access Object)支持。前者提供了对`SqlMapClient`的便捷访问,后者则提供了一系列与Ibatis相关的操作方法,如insert、update、delete和select等。 整合Spring和Ibatis的步骤通常包括以下几步: 1. 创建Web项目并添加Spring支持。 2. 添加Ibatis及其依赖库,包括数据库驱动。 3. 在Spring的配置文件`applicationContext.xml`中配置数据源,由Spring管理。 4. 引入`SqlMapClientFactoryBean`来管理`SqlMapClient`。 5. 编写POJO(Plain Old Java Object)类和对应的映射文件。 6. 配置`SqlMapConfig.xml`,定义Ibatis的相关参数。 7. 如果数据源已由Spring管理,`SqlMapConfig.xml`中不需要再配置数据源。 在Struts、Spring和Ibatis的整合中,Spring主要负责控制流程和数据管理,Struts处理前端请求和视图展示,而Ibatis则专注于数据库操作。这样的三层架构使得各层职责明确,易于维护和扩展。 Spring对Ibatis的整合简化了数据库操作的复杂性,提供了更灵活的事务管理和依赖注入机制,使得开发者可以更专注于业务逻辑的实现,而不是底层的数据库交互。在实际项目中,这种整合方式被广泛应用,提高了开发效率和代码质量。

org.apache.ibatis.exceptions.PersistenceException: ### Error building SqlSession. ### The error may exist in SQL Mapper Configuration ### Cause: org.apache.ibatis.builder.BuilderException: Error parsing SQL Mapper Configuration. Cause: org.apache.ibatis.datasource.DataSourceException: Unknown DataSource property: maxPoolPreparedStatementPerConnectionSize org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:30) org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:80) org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:64) com.ks.Servlet.loginServlet.doGet(loginServlet.java:28) javax.servlet.http.HttpServlet.service(HttpServlet.java:655) javax.servlet.http.HttpServlet.service(HttpServlet.java:764) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) 根本原因。 org.apache.ibatis.builder.BuilderException: Error parsing SQL Mapper Configuration. Cause: org.apache.ibatis.datasource.DataSourceException: Unknown DataSource property: maxPoolPreparedStatementPerConnectionSize org.apache.ibatis.builder.xml.XMLConfigBuilder.parseConfiguration(XMLConfigBuilder.java:121) org.apache.ibatis.builder.xml.XMLConfigBuilder.parse(XMLConfigBuilder.java:99) org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:78) org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:64) com.ks.Servlet.loginServlet.doGet(loginServlet.java:28) javax.servlet.http.HttpServlet.service(HttpServlet.java:655) javax.servlet.http.HttpServlet.service(HttpServlet.java:764) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53) 根本原因。 org.apache.ibatis.datasource.DataSourceException: Unknown DataSource property: maxPoolPreparedStatementPerConnectionSize org.apache.ibatis.datasource.unpooled.UnpooledDataSourceFactory.setProperties(UnpooledDataSourceFactory.java:55) org.apache.ibatis.builder.xml.XMLConfigBuilder.dataSourceElement(XMLConfigBuilder.java:326) org.apache.ibatis.builder.xml.XMLConfigBuilder.environmentsElement(XMLConfigBuilder.java:280) org.apache.ibatis.builder.xml.XMLConfigBuilder.parseConfiguration(XMLConfigBuilder.java:116) org.apache.ibatis.builder.xml.XMLConfigBuilder.parse(XMLConfigBuilder.java:99) org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:78) org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:64) com.ks.Servlet.loginServlet.doGet(loginServlet.java:28) javax.servlet.http.HttpServlet.service(HttpServlet.java:655) javax.servlet.http.HttpServlet.service(HttpServlet.java:764) org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)

221 浏览量

Exception in thread "main" java.lang.NoClassDefFoundError: pojo/User (wrong name: pojo/user) at java.lang.ClassLoader.defineClass1(Native Method) at java.lang.ClassLoader.defineClass(ClassLoader.java:756) at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142) at java.net.URLClassLoader.defineClass(URLClassLoader.java:468) at java.net.URLClassLoader.access$100(URLClassLoader.java:74) at java.net.URLClassLoader$1.run(URLClassLoader.java:369) at java.net.URLClassLoader$1.run(URLClassLoader.java:363) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(URLClassLoader.java:362) at java.lang.ClassLoader.loadClass(ClassLoader.java:418) at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:355) at java.lang.ClassLoader.loadClass(ClassLoader.java:351) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Class.java:348) at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:186) at org.apache.ibatis.io.ClassLoaderWrapper.classForName(ClassLoaderWrapper.java:89) at org.apache.ibatis.io.Resources.classForName(Resources.java:261) at org.apache.ibatis.type.TypeAliasRegistry.resolveAlias(TypeAliasRegistry.java:116) at org.apache.ibatis.builder.BaseBuilder.resolveAlias(BaseBuilder.java:149) at org.apache.ibatis.builder.BaseBuilder.resolveClass(BaseBuilder.java:116) at org.apache.ibatis.builder.xml.XMLStatementBuilder.parseStatementNode(XMLStatementBuilder.java:102) at org.apache.ibatis.builder.xml.XMLMapperBuilder.buildStatementFromContext(XMLMapperBuilder.java:138) at org.apache.ibatis.builder.xml.XMLMapperBuilder.buildStatementFromContext(XMLMapperBuilder.java:131) at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:121) at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:95) at org.apache.ibatis.builder.xml.XMLConfigBuilder.mapperElement(XMLConfigBuilder.java:376) at org.apache.ibatis.builder.xml.XMLConfigBuilder.parseConfiguration(XMLConfigBuilder.java:120) at org.apache.ibatis.builder.xml.XMLConfigBuilder.parse(XMLConfigBuilder.java:99) at org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:78) at org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:64) at MybatisDemo.main(MybatisDemo.java:18)

148 浏览量