数据表
- create database ssm character set utf8;
- use ssm;
- create table account(
- id int primary key auto_increment,
- name varchar(100),
- money double(7,2)
- );
-
创建 Maven 工程
导入 Maven 坐标
- <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/xsd/maven-4.0.0.xsd">
- <modelVersion>4.0.0modelVersion>
-
- <groupId>com.ruochengroupId>
- <artifactId>ssmartifactId>
- <version>1.0-SNAPSHOTversion>
- <packaging>warpackaging>
-
- <properties>
- <maven.compiler.source>8maven.compiler.source>
- <maven.compiler.target>8maven.compiler.target>
- properties>
-
- <dependencies>
-
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-contextartifactId>
- <version>5.0.5.RELEASEversion>
- dependency>
-
- <dependency>
- <groupId>org.aspectjgroupId>
- <artifactId>aspectjweaverartifactId>
- <version>1.8.8version>
- dependency>
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-jdbcartifactId>
- <version>5.0.5.RELEASEversion>
- dependency>
-
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-txartifactId>
- <version>5.0.5.RELEASEversion>
- dependency>
-
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-testartifactId>
- <version>5.0.5.RELEASEversion>
- dependency>
-
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-webmvcartifactId>
- <version>5.0.5.RELEASEversion>
- dependency>
-
-
- <dependency>
- <groupId>javax.servletgroupId>
- <artifactId>servlet-apiartifactId>
- <version>2.5version>
- dependency>
- <dependency>
- <groupId>javax.servlet.jspgroupId>
- <artifactId>jsp-apiartifactId>
- <version>2.0version>
- dependency>
-
-
- <dependency>
- <groupId>org.mybatisgroupId>
- <artifactId>mybatisartifactId>
- <version>3.5.5version>
- dependency>
-
- <dependency>
- <groupId>org.mybatisgroupId>
- <artifactId>mybatis-springartifactId>
- <version>1.3.1version>
- dependency>
- <dependency>
- <groupId>mysqlgroupId>
- <artifactId>mysql-connector-javaartifactId>
- <version>5.1.46version>
- dependency>
-
- <dependency>
- <groupId>c3p0groupId>
- <artifactId>c3p0artifactId>
- <version>0.9.1.2version>
- dependency>
- <dependency>
- <groupId>junitgroupId>
- <artifactId>junitartifactId>
- <version>4.13version>
- <scope>testscope>
- dependency>
- <dependency>
- <groupId>jstlgroupId>
- <artifactId>jstlartifactId>
- <version>1.2version>
- dependency>
- dependencies>
-
- project>
-
编写实体类 Account.java
- package com.ruochen.domain;
-
- public class Account {
-
- private Integer id;
- private String name;
- private Double money;
-
- public Integer getId() {
- return id;
- }
-
- public void setId(Integer id) {
- this.id = id;
- }
-
- public String getName() {
- return name;
- }
-
- public void setName(String name) {
- this.name = name;
- }
-
- public Double getMoney() {
- return money;
- }
-
- public void setMoney(Double money) {
- this.money = money;
- }
-
- @Override
- public String toString() {
- return "Account{" +
- "id=" + id +
- ", name='" + name + '\'' +
- ", money=" + money +
- '}';
- }
- }
-
编写 Mapper 接口
- package com.ruochen.mapper;
-
- import com.ruochen.domain.Account;
-
- import java.util.List;
-
- public interface AccountMapper {
-
- void save(Account account);
-
- List
findAll(); - }
-
编写 Service 接口
- package com.ruochen.service;
-
- import com.ruochen.domain.Account;
-
- import java.util.List;
-
- public interface AccountService {
- void save(Account account);
-
- List
findAll(); -
- }
-
编写 Service 接口实现
- package com.ruochen.service.impl;
-
- import com.ruochen.domain.Account;
- import com.ruochen.mapper.AccountMapper;
- import com.ruochen.service.AccountService;
- import org.apache.ibatis.io.Resources;
- import org.apache.ibatis.session.SqlSession;
- import org.apache.ibatis.session.SqlSessionFactory;
- import org.apache.ibatis.session.SqlSessionFactoryBuilder;
- import org.springframework.stereotype.Service;
-
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.List;
-
- @Service("accountService")
- public class AccountServiceImpl implements AccountService {
- @Override
- public void save(Account account) {
- try {
- InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
- SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
- SqlSession sqlSession = sqlSessionFactory.openSession();
- AccountMapper mapper = sqlSession.getMapper(AccountMapper.class);
- mapper.save(account);
- sqlSession.commit();
- sqlSession.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
-
- @Override
- public List
findAll() { - try {
- InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
- SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
- SqlSession sqlSession = sqlSessionFactory.openSession();
- AccountMapper mapper = sqlSession.getMapper(AccountMapper.class);
- List
accountList = mapper.findAll(); - sqlSession.close();
- return accountList;
- } catch (IOException e) {
- e.printStackTrace();
- }
- return null;
- }
- }
-
编写 Controller
- package com.ruochen.controller;
-
- import com.ruochen.domain.Account;
- import com.ruochen.service.AccountService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Controller;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.ResponseBody;
- import org.springframework.web.servlet.ModelAndView;
-
- import java.util.List;
-
- @Controller
- @RequestMapping("/account")
- public class AccountController {
-
- @Autowired
- private AccountService accountService;
-
- // 保存
- @RequestMapping(value = "/save", produces = "text/html;charset=UTF-8")
- @ResponseBody
- public String save(Account account) {
- accountService.save(account);
- return "保存成功";
- }
-
- // 查询
- @RequestMapping("/findAll")
- public ModelAndView findAll() {
- List
accountList = accountService.findAll(); - ModelAndView modelAndView = new ModelAndView();
- modelAndView.addObject("accountList", accountList);
- modelAndView.setViewName("accountList");
- return modelAndView;
- }
- }
-
编写添加页面
- <%--
- Created by IntelliJ IDEA.
- User: ruochen
- Date: 2022/3/12
- Time: 21:31
- To change this template use File | Settings | File Templates.
- --%>
- <%@ page contentType="text/html;charset=UTF-8" language="java" %>
- <html>
- <head>
- <title>Titletitle>
- head>
- <body>
- <h1>添加账户信息表单h1>
- <form name="accountForm" action="${pageContext.request.contextPath}/account/save" method="post">
- 账户名称:<input type="text" name="name"><br/>
- 账户金额:<input type="text" name="money"><br/>
- <input type="submit" value="保存"><br/>
- form>
- body>
- html>
-
-
编写列表页面
- <%--
- Created by IntelliJ IDEA.
- User: ruochen
- Date: 2022/3/12
- Time: 21:34
- To change this template use File | Settings | File Templates.
- --%>
- <%@ page contentType="text/html;charset=UTF-8" language="java" %>
- <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
- <html>
- <head>
- <title>Titletitle>
- head>
- <body>
- <h1>展示账户数据列表h1>
- <table border="1">
- <tr>
- <th>账户IDth>
- <th>账户名称th>
- <th>账户金额th>
- tr>
- <c:forEach items="${accountList}" var="account">
- <tr>
- <td>${account.id}td>
- <td>${account.name}td>
- <td>${account.money}td>
- tr>
- c:forEach>
- table>
- body>
- html>
编写相应配置文件
applicationContext.xml
- <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"
- xsi:schemaLocation="
- http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
- ">
-
-
- <context:component-scan base-package="com.ruochen">
-
- <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
- context:component-scan>
- beans>
-
spring-mvc.xml
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:mvc="http://www.springframework.org/schema/mvc"
- xmlns:context="http://www.springframework.org/schema/context"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd
- http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
-
-
- <context:component-scan base-package="com.ruochen.controller"/>
-
-
- <mvc:annotation-driven/>
-
-
- <bean id="resourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
- <property name="prefix" value="/WEB-INF/pages/"/>
- <property name="suffix" value=".jsp"/>
- bean>
-
-
- <mvc:default-servlet-handler/>
- beans>
-
AccountMapper.xml
- mapper
- PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
- <mapper namespace="com.ruochen.mapper.AccountMapper">
- <insert id="save" parameterType="account">
- insert into account
- values (#{id}, #{name}, #{money})
- insert>
-
- <select id="findAll" resultType="account">
- select *
- from account
- select>
- mapper>
-
sqlMapConfig.xml
- configuration
- PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-config.dtd">
- <configuration>
-
-
- <properties resource="jdbc.properties"/>
-
-
- <typeAliases>
-
-
- <package name="com.ruochen.domain"/>
- typeAliases>
-
-
- <environments default="development">
- <environment id="development">
- <transactionManager type="JDBC"/>
- <dataSource type="POOLED">
- <property name="driver" value="${jdbc.driver}"/>
- <property name="url" value="${jdbc.url}"/>
- <property name="username" value="${jdbc.username}"/>
- <property name="password" value="${jdbc.password}"/>
- dataSource>
- environment>
- environments>
-
-
- <mappers>
-
- <package name="com.ruochen.mapper"/>
- mappers>
- configuration>
-
jdbc.properties
- jdbc.driver=com.mysql.jdbc.Driver
- jdbc.url=jdbc:mysql://localhost:3306/ssm?useSSL=false&useServerPrepStmts=true&useUnicode=true&characterEncoding=UTF-8
- jdbc.username=root
- jdbc.password=ruochen666
-
web.xml
- <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
- version="4.0">
-
-
- <context-param>
- <param-name>contextConfigLocationparam-name>
- <param-value>classpath:applicationContext.xmlparam-value>
- context-param>
- <listener>
- <listener-class>org.springframework.web.context.ContextLoaderListenerlistener-class>
- listener>
-
-
- <servlet>
- <servlet-name>DispatcherServletservlet-name>
- <servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
- <init-param>
- <param-name>contextConfigLocationparam-name>
- <param-value>classpath:spring-mvc.xmlparam-value>
- init-param>
- <load-on-startup>1load-on-startup>
- servlet>
- <servlet-mapping>
- <servlet-name>DispatcherServletservlet-name>
- <url-pattern>/url-pattern>
- servlet-mapping>
-
-
- <filter>
- <filter-name>CharacterEncodingFilterfilter-name>
- <filter-class>org.springframework.web.filter.CharacterEncodingFilterfilter-class>
- <init-param>
- <param-name>encodingparam-name>
- <param-value>UTF-8param-value>
- init-param>
- filter>
- <filter-mapping>
- <filter-name>CharacterEncodingFilterfilter-name>
- <url-pattern>/*url-pattern>
- filter-mapping>
-
log4j.xml
- ### direct log messages to 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{ABSOLUTE} %5p %c{1}:%L - %m%n
-
- ### direct messages to file mylog.log ###
- log4j.appender.file=org.apache.log4j.FileAppender
- log4j.appender.file.File=c:/mylog.log
- log4j.appender.file.layout=org.apache.log4j.PatternLayout
- log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
-
- ### set log levels - for more verbose logging change 'info' to 'debug' ###
-
- log4j.rootLogger=debug, stdout
-
-
sqlMapConfig.xml
修改如下
- configuration
- PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
- "http://mybatis.org/dtd/mybatis-3-config.dtd">
- <configuration>
-
-
- <typeAliases>
- <package name="com.ruochen.domain"/>
- typeAliases>
-
- configuration>
-
applicationContext.xml
修改如下
- <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:tx="http://www.springframework.org/schema/tx"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xsi:schemaLocation="
- http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
- http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
- http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
- ">
-
-
- <context:component-scan base-package="com.ruochen">
-
- <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
- context:component-scan>
-
-
- <context:property-placeholder location="classpath:jdbc.properties"/>
-
-
- <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
- <property name="driverClass" value="${jdbc.driver}"/>
- <property name="jdbcUrl" value="${jdbc.url}"/>
- <property name="user" value="${jdbc.username}"/>
- <property name="password" value="${jdbc.password}"/>
- bean>
-
-
- <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
- <property name="dataSource" ref="dataSource"/>
-
- <property name="configLocation" value="classpath:sqlMapConfig.xml"/>
- bean>
-
-
- <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
- <property name="basePackage" value="com.ruochen.mapper"/>
- bean>
-
-
-
- <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="dataSource"/>
- bean>
-
-
- <tx:advice id="txAdvice">
- <tx:attributes>
- <tx:method name="*"/>
- tx:attributes>
- tx:advice>
-
-
- <aop:config>
- <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.ruochen.service.impl.*.*(..))"/>
- aop:config>
- beans>
-
AccountServiceImpl.java
修改如下
- package com.ruochen.service.impl;
-
- import com.ruochen.domain.Account;
- import com.ruochen.mapper.AccountMapper;
- import com.ruochen.service.AccountService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
-
- import java.util.List;
-
- @Service("accountService")
- public class AccountServiceImpl implements AccountService {
-
- @Autowired
- private AccountMapper accountMapper;
-
- @Override
- public void save(Account account) {
- accountMapper.save(account);
- }
-
- @Override
- public List
findAll() { - return accountMapper.findAll();
- }
- }
-
报错:
Method com/mchange/v2/c3p0/impl/NewProxyResultSet.isClosed()Z is abstract
解决方法 在pom.xml
文件中修改C3P0的依赖包
<dependency> <groupId>com.mchangegroupId> <artifactId>c3p0artifactId> <version>0.9.5.2version> dependency>