ssm整合实现简单的增删改查

通过三天的时间,跟着视频学习然后做出来了

只是最基本的增删改查,学到了一些比较"小心机"的设计,期间出了不少问题让我一度想要放弃,重要的内容借此平台总结一下

web.xml,主要用于配置Filter,Servlet,Lisenter等

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://xmlns.jcp.org/xml/ns/javaee"
    xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
    version="3.1">
    <display-name>usermanage</display-name>
    <!-- 配置spring容器初始化监听器 -->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:spring/applicationContext*.xml</param-value>
    </context-param>
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

    <!-- 配置编码的过滤器 -->
    <filter>
        <filter-name>encoding</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf8</param-value>
        </init-param>
    </filter>

    <filter-mapping>
        <filter-name>encoding</filter-name>
        <!--拦截路径 -->
        <url-pattern>/*</url-pattern>
    </filter-mapping>

    <!-- 配置DispatcherServlet -->
<servlet>

<servlet-name>usermanage</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/usermanage-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
<servlet-name>usermanage</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>

    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
        <welcome-file>index.htm</welcome-file>
        <welcome-file>index.jsp</welcome-file>
        <welcome-file>default.html</welcome-file>
        <welcome-file>default.htm</welcome-file>
        <welcome-file>default.jsp</welcome-file>
    </welcome-file-list>
</web-app>

usermanage-servlet.xml,对应于Controller

主要步骤:配置注解驱动;开启注解扫描;解决静态资源的拦截问题;配置视图解析器

<?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.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">

    <mvc:view-controller path="/user/users" view-name="users"/>
    <mvc:view-controller path="/user/page/add" view-name="user-add"/>
    <mvc:view-controller path="/user/page/edit" view-name="user-edit"/>

    <!-- 配置注解驱动:替代推荐使用的注解映射器和适配器,提供对json的支持 -->
    <mvc:annotation-driven />

    <!-- 开启注解扫描,和spring是一样的 -->
    <context:component-scan base-package="com.cn.usermanage.controller" />

    <!-- 解决静态资源被拦截的问题 -->
    <mvc:default-servlet-handler/>

    <!-- 配置视图解析器 -->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/views/"></property>
        <property name="suffix" value=".jsp"></property>
    </bean>

</beans>

applicationContext.xml 中需要配置(省略数据库的配置文件)

<!-- 注解扫描 -->
    <context:component-scan base-package="com.cn.usermanage.service"/>
    <!-- 加载资源文件 -->
    <context:property-placeholder location="classpath:jdbc.properties"/>
    <!-- 配置数据源 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="user" value="${jdbc.user}" />
        <property name="password" value="${jdbc.password}" />
        <property name="jdbcUrl" value="${jdbc.url}" />
        <property name="driverClass" value="${jdbc.driver}" />
    </bean>

applicationContext-mybatis.xml中需要配置,和利用mybatis操作数据库相关

步骤:需要初始化SqlsessionFactory对象;配置Mapper接口的包扫描

<!-- spring初始化bean的方式: 1.无参构造 2.静态工厂方法 3.实例化工厂 4.工厂bean -->
    <bean id="sqlSessionFactory"
        class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 指定数据源 -->
        <property name="dataSource" ref="dataSource" />
        <!-- 指定全局配置文件 -->
        <property name="configLocation"
            value="classpath:mybatis/mybatis-config.xml"></property>
        <!-- 指定映射文件(不需要mybatis-config.xml中映射),利用通配符匹配任意目录任意xml配置 -->
                <property name="mapperLocations" value="classpath:mybatis/mappers/**/*.xml"></property>

        <!-- 开启别名扫描 -->
        <property name="typeAliasesPackage"
            value="com.cn.usermanage.pojo"></property>
    </bean>

                <!-- 配置mapper接口的包扫描 -->

     <mybatis-spring:scan
        base-package="com.cn.usermanage.mapper" /> 

mybatis-config.xml只需要配置行为参数即可

<settings>
        <setting name="mapUnderscoreToCamelCase" value="true" />
    </settings>

实体类对象User可以通过注解的方式对属性进行数据校验,常用的注解如:

  • @Null    验证对象是否为 null
  • @NotNull    验证对象是否不为 null
  • @Size(min,max)    验证对象长度是否在给定的范围内
  • @Past    验证 Date 和 Calendar 对象是否在当前时间之前
  • @Future    验证 Date 和 Calendar 对象是否在当前时间之后
  • @Pattern    验证 String 对象是否符合正则表达式的规则
  • @NotBlank    检查字符串是不是 Null,被 Trim 的长度是否大于0,只对字符串,且会去掉前后空格
  • @URL    验证是否是合法的 url
  • @Email    验证是否是合法的邮箱

User.java

public class User {

    private Long id;

    // 用户名
    @NotNull
    @Length(min=6, max=20, message="用户名长度不合法")
    private String userName;

    // 密码
    @JsonIgnore
    @NotNull
    @Length(min=6, max=20, message="用户名长度不合法")
    private String password;

    // 姓名
    @NotNull
    private String name;

    // 年龄
    @NotNull
    private Integer age;

    // 性别,1男性,2女性
    @NotNull
    private Integer sex;

    // 出生日期
    @NotNull
    @DateTimeFormat(pattern="yyyy-MM-dd")
    @Past(message="生日必须是过去式")
    private Date birthday;

    // 创建时间
    private Date created;

    // 更新时间
    private Date updated;}

UserController.java

@Controller
@RequestMapping("user")
public class UserController {
    @Autowired
    private UserService userService;

    @RequestMapping("users")
    public String toUsers() {
        return "users";
    }

    @RequestMapping("list")
    @ResponseBody
    public Map<String, Object> queryUserAll() {
        Map<String, Object> map = new HashMap<>();
        // 查询总条数
        Long total = this.userService.queryTotal();
        map.put("total", total);
        List<User> users = this.userService.queryUserAll();
        map.put("rows", users);
        return map;
    }

    @RequestMapping("save")
    @ResponseBody
    public Map<String, String>  saveUser(@Valid User user,BindingResult result)
    {
        Map<String,String> map=new HashMap<>();

        if(result.hasErrors())
        {
            //输出到控制台
            System.out.println(result.getAllErrors());            //status用于前端校验是否执行成功
            map.put("status", "500");
            return map;

        }
        //调用Service方法新增用户信息
        Boolean flag=this.userService.saveUser(user);
        if(flag)
            map.put("status", "200");
        else
            map.put("status", "500");
        return map;

    }

    //修改

    @RequestMapping("edit")
    @ResponseBody

    public Map<String, String>  editUser(@Valid User user)
    {
        Map<String,String> map=new HashMap<>();
        //调用Service方法新增用户信息
        Boolean flag=this.userService.editUser(user);
        if(flag)
            map.put("status", "200");
        else
            map.put("status", "500");
        return map;

    }

    //删除

    @RequestMapping("delete")
    @ResponseBody
    public Map<String, String>  deleteUser(@RequestParam("ids")List<Long> ids )
    {
        Map<String,String> map=new HashMap<>();
        //调用Service方法新增用户信息
        Boolean flag=this.userService.deleteUserByIds(ids);
        if(flag)
            map.put("status", "200");
        else
            map.put("status", "500");
        return map;

    }
}

原文地址:https://www.cnblogs.com/ywqtro/p/12324352.html

时间: 2024-07-31 10:29:40

ssm整合实现简单的增删改查的相关文章

SSM整合初级 简单的增删改查

1.jar包 2.mybatis-config.xm配置文件 <?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

Maven+SSM框架实现简单的增删改查

Spring介绍: spring 使用基本的 JavaBean 来完成以前只可能由 EJB 完成的事情.然而, Spring的用途不仅限于服务器端的开发.从简单性.可测试性和松耦合的角度而言,任何Java 应用都可以从 Spring 中受益. 简单来说, Spring 是一个轻量级的控制反转(IoC )和面向切面( AOP )的容器框架. SpringMVC介绍 Spring MVC 属于 SpringFrameWork 的后续产品,已经融合在Spring Web Flow 里面. Spring

MyBatis学习--简单的增删改查

jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: 1 Public static void main(String[] args) { 2 Connection connection = null; 3 PreparedStatement preparedStatement = null; 4 ResultSet resultSet = null; 5 6 try { 7 //加载数据库驱动 8 Class.forName

MyBatis3.2.2+SpringMVC3.0 简单实现(增删改查,Web版实现)

MyBatis3.2.2+SpringMVC3.0 简单实现(增删改查,Web版实现) 首先,需要知道Eclipse如何创建Dynamic Web Project for Maven,我们首先需要知道如何用Eclipse创建动态部署的Maven Web-app 项目.参考以下链接的博客:http://blog.csdn.net/smilevt/article/details/8215558. 构建完之后:实现具体的增删改查,不去部署Web war的时候我们用Junit单元测试CRUD功能.代码如

Mybatis使用之简单的增删改查

Mybatis使用之简单的增删改查 一:简介 主要记录最简单的数据的增删改查.下一章会有各个操作详细一点的配置说明.以Author表为例(见上一博客).Author表没有关联任何其他表.也没有特殊字段. 二:映射规则 2.1.映射文件中的sql方法与对应的XxxMapper接口中的方法映射规则: a)映射文件的namespace的值是XxxMapper接口的全限定名.即包名+接口名称 b)映射文件中表示增删改查的标签(select.insert.delete.update)的id的值是接口中方法

EF5(6) 简单三层 增删改查

1:项目结构 2:每层添加对其他层的引用,这里我们把除了Web层之外的所有的层生成的文件都放到解决方案下的Library文件夹下,然后每个项目分别来引用里面的dll项目文件. 我们在Model项目上,右键属性->生成-> 在下面的输出里面,选择上一级的 Library文件夹 2.2 我们调整项目的生成顺序 ,在解决方案或者是任意项目上右键,选择 生成依赖项,调整各个项目的依赖,这样的目的就是调整项目的生成顺序. 注意,这里你选择依赖项,并没有给项目与项目之间增加了dll的引用,只是单纯的修改了

通过JDBC进行简单的增删改查

通过JDBC进行简单的增删改查(以MySQL为例) 目录 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JDBC基本操作 (1)定义记录的类(可选) (2)连接的获取 (3)insert (4)update (5)select (6)delete 四.测试 五.代码分析 六.思考问题 前言:什么是JDBC 维基百科的简介: Java 数据库连接,(Java Database Connectivity,简称JDBC)

用CI框架向数据库中实现简单的增删改查

以下代码基于CodeIgniter_2.1.3版 用PHP向数据库中实现简单的增删改查(纯代码)请戳 http://www.cnblogs.com/corvoh/p/4641476.html CodeIgniter_2.1.3与PHP5.6的兼容问题请戳 http://www.cnblogs.com/corvoh/p/4649357.html 增: //insert//语法:$bool=$this->db->insert('表名',关联数组); $data=array( 'username'=

用PHP向数据库中实现简单的增删改查(纯代码,待完善)

<?php $con = mysql_connect("localhost:3306","root",""); if (!$con) { die('Could not connect: ' . mysql_error()); } mysql_select_db("test", $con); $result = mysql_query("SELECT * FROM user"); echo "