搭建ssm框架(Spring+Springmvc+mybatis) 实现一般性的增删改查

首先创建一个个人信息表来实现增删改查的操作.
创建个人信息表 t_personal

DROP TABLE IF EXISTS `t_personal`;
CREATE TABLE `t_personal` (
  `id` bigint(11) NOT NULL AUTO_INCREMENT COMMENT '自增id',
  `name` varchar(255) NOT NULL DEFAULT '' COMMENT '名称',
  `age` bigint(3) NOT NULL DEFAULT '0',
  `sex` varchar(1) NOT NULL DEFAULT '' COMMENT '性别',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk COMMENT='个人信息表';

现在已经建立了一个数据库表
接下来建一个maven项目.
记得要创建webapp的maven
项目结构如下:

结构

这里面有一个PrintReqUriFilter.java是因为我没有配置路径拦截并将访问的编码格式改为UTF-8

package com.easyit.ssm.common;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.log4j.Logger;

@WebFilter("/*")
public class PrintReqUriFilter implements Filter{
	private final static Logger log = Logger.getLogger(PrintReqUriFilter.class);

	@Override
	public void destroy() {
		log.info("销毁........");
	}

	@Override
	public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2)
			throws IOException, ServletException {
		HttpServletRequest request = (HttpServletRequest) arg0;
		HttpServletResponse response = (HttpServletResponse) arg1;
		String url = request.getRequestURI();
		request.setCharacterEncoding("utf-8");
		response.setCharacterEncoding("utf-8");
		arg2.doFilter(arg0, arg1);
		log.info(url);
	}

	@Override
	public void init(FilterConfig arg0) throws ServletException {
		log.info("初始化.....");
	}

}

建好后的pom.xml文件如下:

<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.easyit</groupId>
  <artifactId>personal</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <name>personal Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  </properties>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
    
     <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
	<dependency>
	    <groupId>javax.servlet</groupId>
	    <artifactId>javax.servlet-api</artifactId>
	    <version>4.0.0</version> 
	    <scope>provided</scope>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-webmvc</artifactId>
	    <version>5.0.0.RELEASE</version>
	</dependency>
    
    <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
	<dependency>
	    <groupId>org.mybatis</groupId>
	    <artifactId>mybatis</artifactId>
	    <version>3.2.8</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis-spring -->
	<dependency>
	    <groupId>org.mybatis</groupId>
	    <artifactId>mybatis-spring</artifactId>
	    <version>1.3.2</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/com.mchange/c3p0 -->
	<dependency>
	    <groupId>com.mchange</groupId>
	    <artifactId>c3p0</artifactId>
	    <version>0.9.5.2</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc -->
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-jdbc</artifactId>
	    <version>5.0.0.RELEASE</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
	<dependency>
	    <groupId>mysql</groupId>
	    <artifactId>mysql-connector-java</artifactId>
	    <version>5.1.26</version>
	</dependency>
    
    <!-- https://mvnrepository.com/artifact/org.springframework/spring-beans -->
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-beans</artifactId>
	    <version>5.0.0.RELEASE</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-validator -->
	<dependency>
	    <groupId>org.hibernate</groupId>
	    <artifactId>hibernate-validator</artifactId>
	    <version>5.4.1.Final</version>
	</dependency>
	
	<dependency>
		<groupId>org.springframework</groupId>
	 	<artifactId>spring-context</artifactId>
	 	<version>5.0.0.RELEASE</version>
	</dependency>
    
    <!-- https://mvnrepository.com/artifact/org.springframework/spring-context-support -->
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-context-support</artifactId>
	    <version>5.0.0.RELEASE</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
	<dependency>
	    <groupId>org.slf4j</groupId>
	    <artifactId>slf4j-api</artifactId>
	    <version>1.7.22</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-log4j12 -->
	<dependency>
	    <groupId>org.slf4j</groupId>
	    <artifactId>slf4j-log4j12</artifactId>
	    <version>1.7.22</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/commons-beanutils/commons-beanutils -->
	<dependency>
	    <groupId>commons-beanutils</groupId>
	    <artifactId>commons-beanutils</artifactId>
	    <version>1.9.3</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/com.google.code.gson/gson -->
	<dependency>
	    <groupId>com.google.code.gson</groupId>
	    <artifactId>gson</artifactId>
	    <version>2.8.5</version>
	</dependency>
	
	<!-- https://mvnrepository.com/artifact/javax.servlet/jstl -->
	<dependency>
	    <groupId>javax.servlet</groupId>
	    <artifactId>jstl</artifactId>
	    <version>1.2</version>
	</dependency>
  </dependencies>
  <build>
    <finalName>personal</finalName>
    <plugins>
      <!-- compiler插件, 设定JDK版本 -->
      <plugin>
          <groupId>org.apache.maven.plugins</groupId>
          <artifactId>maven-compiler-plugin</artifactId>
          <version>2.5</version>
          <configuration>
              <source>1.8</source>
              <target>1.8</target>
              <showWarnings>true</showWarnings>
          </configuration>
      </plugin>
 	 </plugins>
  </build>
</project>

然后是jdbc.properties
注意这里是mysql数据库,iphone是你建立t_personal表的数据库,name是数据库的账号,password是账号密码.

driverClass=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/iphone
name=root
password=root

接下来是一个log4j.properties文件

# Root logger option
log4j.rootLogger=debug, stdout

# 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.file.layout.ConversionPattern=%d{yy/MM/dd HH:mm:ss} %p %c{2}: %m%n

然后是mybatis.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" 
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
	<!-- 这里会通过log4j将SQL语句处理语句打印出来,非常方便 -->
	<settings>
		 <setting name="logImpl" value="STDOUT_LOGGING" />
	</settings>
	<mappers>
		<mapper resource="personal.xml" />
	</mappers>
</configuration> 

然后对应实体类Personal.java

package com.easyit.ssm.model;

public class Personal {
	private Long id;
	private String name;
	private Long age;
	private String sex;

	public Personal() {
	}

	public Personal(Long id, String name, Long age, String sex) {
		super();
		this.id = id;
		this.name = name;
		this.age = age;
		this.sex = sex;
	}

	public Long getId() {
		return id;
	}

	public void setId(Long id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public Long getAge() {
		return age;
	}

	public void setAge(Long age) {
		this.age = age;
	}

	public String getSex() {
		return sex;
	}

	public void setSex(String sex) {
		this.sex = sex;
	}

	@Override
	public String toString() {
		return "Personal [id=" + id + ", name=" + name + ", age=" + age + ", sex=" + sex + "]";
	}
}

然后是personal.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  
<mapper namespace="com.easyit.ssm.dao.PersonalDao">

	<resultMap type="com.easyit.ssm.model.Personal" id="personalMap">
		<id column="id" property="id"/>
		<result column="name" property="name"/>
		<result column="age" property="age"/>
		<result column="sex" property="sex"/>
	</resultMap>
	
	<!-- 添加个人信息 -->
	<insert id="insertPersonal">
		insert into t_personal(name,age,sex) values(#{name},#{age},#{sex})
	</insert>
	
	<!-- 修改年龄 -->
	<update id="updatePersonal">
		update t_personal set age = #{age} where id = #{id}
	</update>
	
	<!-- 删除个人信息 -->
	<delete id="deletePersonal">
		delete from t_personal where id = #{id}
	</delete>

	<select id="selectPersonalToName" resultMap="personalMap">
		select * from t_personal where name like '#{name}'
	</select>
	
	<select id="selectPersonalToSex" resultMap="personalMap">
		select * from t_personal where sex = #{sex}
	</select>
	
</mapper>

说明一下#与$处理SQL语句的区别

#{} 表示在预处理中会把参数部分用?占位符,能够防止大量sql语句注入.
${} 表示在动态解析过程中,会直接将数据替代进去,可能会导致大量SQL语句注入

然后是personal.xml的命名空间PersonalDao.java

package com.easyit.ssm.dao;

import java.util.List;

import org.apache.ibatis.annotations.Param;

import com.easyit.ssm.model.Personal;

public interface PersonalDao {

	// 添加一条个人信息
	int insertPersonal(Personal personal);

	// 修改个人信息
	int updatePersonal(Long id, Long age);

	// 删除个人信息
	int deletePersonal(Long id);

	// 通过名字查询个人信息
	List<Personal> selectPersonalToName(@Param("name") String name);

	// 通过性别查询个人信息
	List<Personal> selectPersonalToAge(String sex);

}

现在配置命名空间Dao接口的xml

dao.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:context="http://www.springframework.org/schema/context"
	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/aop
        http://www.springframework.org/schema/aop/spring-aop.xsd
        http://www.springframework.org/schema/mvc 
        http://www.springframework.org/schema/mvc/spring-mvc.xsd">
    
    <context:property-placeholder location="classpath:jdbc.properties" />

	<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<property name="driverClass" value="${driverClass}"></property>
		<property name="jdbcUrl" value="${url}"></property>
		<property name="user" value="${name}"></property>
		<property name="password" value="${password}"></property>
	</bean>

	<!-- spring sessionFactoryBean 该类实现Spring 的FactoryBean 接口 getObject 返回SqlSessionFactroy对象 -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="configLocation" value="classpath:mybatis.xml"></property>
		<property name="dataSource" ref="dataSource"></property>
	</bean>

	<!-- mybatis自动扫描加载Sql映射文件/接口 : MapperScannerConfigurer sqlSessionFactory 
		basePackage:指定sql映射文件/接口所在的包(自动扫描) -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<!--配置扫描的包位置,扫描会创建该包下面所有接口的Mybatis 映射代理对象  -->
	  	<property name="basePackage" value="com.easyit.ssm.dao" />
	  	<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
	</bean>
   
</beans>

然后是代理接口以及代理接口实现类
PersonalService.xml

package com.easyit.ssm.service;

import java.util.List;

import org.apache.ibatis.annotations.Param;

import com.easyit.ssm.model.Personal;

public interface PersonalService {
	// 添加一条个人信息
	int insertPersonal(Personal personal);

	// 修改个人信息
	int updatePersonal(Long id, Long age);

	// 删除个人信息
	int deletePersonal(Long id);

	// 通过名字查询个人信息
	List<Personal> selectPersonalToName(String name);

	// 通过性别查询个人信息
	List<Personal> selectPersonalToAge(String sex);
}

这里的方法名可以不一样,但是返回值要一样,我就偷懒一波写一模一样的了.

然后是实现类

package com.easyit.ssm.service.impl;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.easyit.ssm.dao.PersonalDao;
import com.easyit.ssm.model.Personal;
import com.easyit.ssm.service.PersonalService;

@Service
public class PersonalServiceImpl implements PersonalService {

	@Autowired
	PersonalDao personalDao;

	@Override
	public int insertPersonal(Personal personal) {
		// 这里是可以写代码出理的
		return personalDao.insertPersonal(personal);
	}

	@Override
	public int updatePersonal(Long id, Long age) {
		// 这里是可以写代码出理的
		return personalDao.updatePersonal(id, age);
	}

	@Override
	public int deletePersonal(Long id) {
		// 这里是可以写代码出理的
		return personalDao.deletePersonal(id);
	}

	@Override
	public List<Personal> selectPersonalToName(String name) {
		// 这里是可以写代码出理的
		return personalDao.selectPersonalToName(name);
	}

	@Override
	public List<Personal> selectPersonalToSex(String sex) {
		// 这里是可以写代码出理的
		return personalDao.selectPersonalToSex(sex);
	}

}

然后是出来代理接口与代理接口实现类的
spring.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:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	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/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">


	<context:annotation-config />
	<!-- 启动注解扫描 -->
	<mvc:annotation-driven />
	<context:component-scan base-package="com.easyit.ssm.service.impl"></context:component-scan>
	
</beans>

然后是springmvc.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:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	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/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">

	<!-- 启动MVC扫描 -->
	<mvc:annotation-driven />
	
	<context:component-scan base-package="com.easyit.shiro.controller"></context:component-scan>

	<!-- 配置视图解析器 -->
	<!-- <bean id="viewResolver"
		class="org.springframework.web.servlet.view.UrlBasedViewResolver">
		<property name="viewClass"
			value="org.springframework.web.servlet.view.JstlView" />
		<property name="prefix" value="/WEB-INF/jsp/" />
		<property name="suffix" value=".jsp" />
	</bean>
	
	<mvc:view-controller path="/unauthor" view-name="unauthor"/>
	<mvc:view-controller path="/login" view-name="login"/>
	<mvc:view-controller path="/" view-name="login"/>
	<mvc:view-controller path="/register" view-name="register"/>
	<mvc:view-controller path="/add" view-name="addUser"/> -->

</beans>

然后最重要的是web.xml的配置

<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	      http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0">

	<!-- 配置Spring上下文监听器,该监听器WEB启动时,初始化Spring上下文 -->
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>
	
	<servlet>
		<servlet-name>DispatcherServlet</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

		<!-- 配置文件 -->
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath:springmvc.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>
	
	<servlet-mapping>
	    <servlet-name>default</servlet-name>
	    <url-pattern>*.js</url-pattern>
	    <url-pattern>*.css</url-pattern>
	    <url-pattern>*.jpg</url-pattern>
	    <url-pattern>*.jpeg</url-pattern>
	</servlet-mapping>

	<!-- 配置Spring映射 -->

	<servlet-mapping>
		<servlet-name>DispatcherServlet</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>
	
	<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>classpath:spring.xml,classpath:dao.xml</param-value>
	</context-param>
	
</web-app>

然后运行项目(我是用jetty的)
没有报错就表示运行成功了
然后到浏览器上访问如图:

这里写图片描述

说明就成功了.

然后在简单的描述一下PersonalController.java

package com.easyit.ssm.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import com.easyit.ssm.service.PersonalService;

@Controller
public class PersonalController {

	@Autowired
	PersonalService personalService;

	@RequestMapping("/add")
	public String personalAdd(/* 参数 */) {

		// 代码操作
		
		//return "forward:/select";
		return "要跳转的文件路径";
	}

	@RequestMapping("/select")
	public String personalSelect(/* 参数 */){
			// 代码操作
		return "要跳转的文件路径";	
	}
}

controller层中的return也可以使用forward与redirect
详情请参考https://blog.csdn.net/qq_43052309/article/details/82260828

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SSM框架是指Spring+SpringMVC+MyBatis的组合,是一种非常流行的Java Web开发框架。下面我将讲解一下在SSM框架中进行增删改查的过程。 1. 增加数据: 在SSM框架中,增加数据的过程一般分为以下几个步骤: (1)在Spring配置文件中配置数据源和MyBatis的SqlSessionFactory,以及事务管理器。 (2)在MyBatis的映射文件中编写相应的SQL语句,通过Mapper接口调用SQL语句。 (3)在SpringMVC的控制器中注入Mapper接口,通过调用Mapper接口的方法来实现数据的插入操作。 2. 删除数据: 删除数据的过程与增加数据类似,也分为以下几个步骤: (1)在Spring配置文件中配置数据源和MyBatis的SqlSessionFactory,以及事务管理器。 (2)在MyBatis的映射文件中编写相应的SQL语句,通过Mapper接口调用SQL语句。 (3)在SpringMVC的控制器中注入Mapper接口,通过调用Mapper接口的方法来实现数据的删除操作。 3. 修改数据: 修改数据的过程与增加、删除数据类似,也分为以下几个步骤: (1)在Spring配置文件中配置数据源和MyBatis的SqlSessionFactory,以及事务管理器。 (2)在MyBatis的映射文件中编写相应的SQL语句,通过Mapper接口调用SQL语句。 (3)在SpringMVC的控制器中注入Mapper接口,通过调用Mapper接口的方法来实现数据的修改操作。 4. 查询数据: 查询数据的过程与增加、删除、修改数据类似,也分为以下几个步骤: (1)在Spring配置文件中配置数据源和MyBatis的SqlSessionFactory,以及事务管理器。 (2)在MyBatis的映射文件中编写相应的SQL语句,通过Mapper接口调用SQL语句。 (3)在SpringMVC的控制器中注入Mapper接口,通过调用Mapper接口的方法来实现数据的查询操作。 以上就是在SSM框架中进行增删改查的过程。需要注意的是,在实际开发中,我们需要根据具体的业务需求来优化代码,提高程序的性能和安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值