Bootstrap+spring+springmvc+mybatis实现基本的增删改查(源码)

做个小列子,首先我这里先将spring+springmvc+mybatis整合好:

首先,给大家看一下我项目的构造:

Bootstrap+spring+springmvc+mybatis实现基本的增删改查(源码)_第1张图片

1.第一步:我先将我项目中要是用的所有依赖导入:

 
    <dependency>
      <groupId>junitgroupId>
      <artifactId>junitartifactId>
      <version>4.12version>
      <scope>testscope>
    dependency>
    
    <dependency>
      <groupId>org.mybatisgroupId>
      <artifactId>mybatisartifactId>
      <version>3.4.5version>
    dependency>
    
    <dependency>
      <groupId>mysqlgroupId>
      <artifactId>mysql-connector-javaartifactId>
      <version>5.1.43version>
    dependency>

    <dependency>
      <groupId>org.springframeworkgroupId>
      <artifactId>spring-webmvcartifactId>
      <version>4.3.3.RELEASEversion>
    dependency>
    
    <dependency>
      <groupId>com.mchangegroupId>
      <artifactId>c3p0artifactId>
      <version>0.9.5.1version>
    dependency>
    <dependency>
      <groupId>org.springframeworkgroupId>
      <artifactId>spring-jdbcartifactId>
      <version>4.3.10.RELEASEversion>
    dependency>
    <dependency>
      <groupId>org.mybatisgroupId>
      <artifactId>mybatis-springartifactId>
      <version>1.3.1version>
    dependency>

    <dependency>
      <groupId>com.fasterxml.jackson.coregroupId>
      <artifactId>jackson-databindartifactId>
      <version>2.9.1version>
    dependency>

    <dependency>
      <groupId>com.fasterxml.jackson.coregroupId>
      <artifactId>jackson-coreartifactId>
      <version>2.9.1version>
    dependency>

    <dependency>
      <groupId>com.fasterxml.jackson.coregroupId>
      <artifactId>jackson-annotationsartifactId>
      <version>2.9.1version>
    dependency>

    <dependency>
      <groupId>javax.servletgroupId>
      <artifactId>javax.servlet-apiartifactId>
      <version>4.0.0version>
      <scope>providedscope>
    dependency>

    
    <dependency>
      <groupId>com.alibabagroupId>
      <artifactId>fastjsonartifactId>
      <version>1.2.30version>
    dependency>

2.关于ssm的整合我这里就不细说了,之前的博客就讲了关于 spring+springmvc+mybatis的整合(http://blog.csdn.net/desert568/article/details/79082067)

,所以我这里就直接上代码:

我的数据库连接池:db.properties:

uname=root
upass=root
url=jdbc:mysql://localhost:3306/test
driver_Class=com.mysql.jdbc.Driver

initPoolSize=5
maxPoolSize=20

3.ApplicationContext.xml配置文件:

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

    
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="user" value="${uname}">property>
        <property name="password" value="${upass}">property>
        <property name="jdbcUrl" value="${url}">property>
        <property name="driverClass" value="${driver_Class}">property>
        <property name="initialPoolSize" value="${initPoolSize}">property>
        <property name="maxPoolSize" value="${maxPoolSize}">property>
    bean>

    
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
      <property name="dataSource" ref="dataSource">property>
       <property name="configLocation" value="classpath:mybatis-config">property>
        <property name="mapperLocations" value="classpath:com/desert/entity/*.xml">property>
    bean>

    <bean id="scannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.desert.dao">property>
    bean>

beans>

4.然后再是我的springmvc配置文件:
xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       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:component-scan base-package="com.desert.controller">context:component-scan>

    
    <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        
        <property name="prefix" value="/">property>
        
        <property name="suffix" value=".jsp">property>
    bean>

    <mvc:annotation-driven>mvc:annotation-driven>

beans>

5.web.xml:

 web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
  <display-name>Archetype Created Web Applicationdisplay-name>

  <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>springMVCservlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
      
    <init-param>
      <param-name>contextConfigLocationparam-name>
      <param-value>classpath:springmvc.xmlparam-value>
    init-param>
  
  servlet>
   
  
  <servlet-mapping>
    <servlet-name>springMVCservlet-name>
    <url-pattern>*.actionurl-pattern>
  servlet-mapping>

web-app>

6.person实体类:
private String pname;
private int pid;
private int page;
7.我的PersonDao接口:
public interface IPerson01 {

    public List getallPerson(Map map);

    public List getallPersonByPname(Map map);

    public Person getPersonById(int pid);

    public void delperson(int pid);

    public void addperson(Person person);

    public void updateperson(Person person);

}


8.Person.xml配置文件:
xml version="1.0" encoding="UTF-8" ?>
 mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.desert.dao.IPerson01">
    <select id="getPersonById" parameterType="int" resultType="com.desert.entity.Person">
        select * from person where pid=#{pid}
    select>

    <select id="getallPerson" resultType="com.desert.entity.Person" parameterType="map">
        select * from person limit #{offset},#{pageSize}
    select>


    <select id="getallPersonByPname" resultType="com.desert.entity.Person" parameterType="map">
        select * from person p
        <where>
            <if test="pname != null">
                and p.pname like '%${pname}%'
            if>
            <if test="page != null">
                and p.page =#{page}
            if>
        where>
        limit #{offset},#{pageSize}
    select>

    <delete id="delperson" parameterType="int">
        delete from person where pid=#{pid}
    delete>

    <insert id="addperson" parameterType="com.desert.entity.Person">
        insert into person(pname,page)
        values(#{pname},#{page})
    insert>

    <update id="updateperson" parameterType="com.desert.entity.Person">
        update person set pname =#{pname}, page =#{page} where pid=#{pid}
    update>
    
mapper>

9.然后再是我的PersonController:

@Controller
public class PersonController {

    @Autowired
    private IPerson01 iPerson01;

    @RequestMapping("getPerson")
    public String getPerson(){

        Person person=iPerson01.getPersonById(1);
        System.out.println(person);
        return "success";
    }
    

    @RequestMapping("getsecondall")
    public void getsecondall(HttpServletResponse resp, HttpServletRequest request) throws IOException {


        //得到客户端传递的页码和每页记录数,并转换成int类型
        int pageSize = Integer.parseInt(request.getParameter("pageSize"));
        int pageNumber = Integer.parseInt(request.getParameter("pageNumber"));
        //查询参数
        String pname = request.getParameter("orderNum");
        String age=request.getParameter("page");

        int offset=(pageNumber-1)*pageSize;  //当前起始页
        //定义map集合:
        Map mp=new HashMap();
        //分页:
        mp.put("offset",offset);
        mp.put("pageSize",pageSize);

        if(age.length()>0){
             int page=Integer.parseInt(age);
            mp.put("page",page);
        }
        if(pname.length()>0){
            mp.put("pname",pname);
        }
      //分页:
        List la = iPerson01.getallPersonByPname(mp);
       // System.out.println(mp.get("page")+","+mp.get("pname"));
        Map map = new HashMap();
        map.put("total",la.size());
        map.put("rows",la);
        PrintWriter out=resp.getWriter();
        String s= JSON.toJSONString(map);
       // System.out.println(s);
        out.write(s);
        out.flush();
        out.close();

    }

    //删除:
    @RequestMapping("delPerson")
    public void delPerson(HttpServletResponse resp, HttpServletRequest request) throws IOException {

        //得到传过来的字符串:
        String str=request.getParameter("str");
        //将字符串转化为数组:
        JSONArray jsons=JSONArray.parseArray(str);
        for (Object object : jsons) {
            int id=Integer.parseInt(object.toString());
            System.out.println(id);
            iPerson01.delperson(id);
        }
        //返回:
        PrintWriter out=resp.getWriter();
        out.write("1");
        out.flush();
        out.close();

    }

    //添加:
    @RequestMapping("addPerson")
    public void addPerson(HttpServletResponse resp, HttpServletRequest request) throws IOException {

        //得到传过来的字符串:
        String str=request.getParameter("str");
        //将字符串转化为数组:
        //将str转化为Area对象:
        Person person=JSON.parseObject(str, Person.class);
        System.out.println(person);
        //添加:
        iPerson01.addperson(person);
        //返回:
        PrintWriter out=resp.getWriter();
        out.write("1");
        out.flush();
        out.close();

    }

    //修改:
    @RequestMapping("updatePerson")
    public void updatePerson(HttpServletResponse resp, HttpServletRequest request) throws IOException {

        //得到传过来的字符串:
        String str=request.getParameter("str");
        //将字符串转化为数组:
        //将str转化为Area对象:
        Person person=JSON.parseObject(str, Person.class);
        //添加:
        iPerson01.updateperson(person);
        //返回:
        PrintWriter out=resp.getWriter();
        out.write("1");
        out.flush();
        out.close();

    }

}
10.最后,就是我的界面,second.jsp:
我这里的css和js都是直接用网上的,所以联网就可以,不用去下载什么js文件了:

<link href="https://cdn.bootcss.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet">

<link href="https://cdn.bootcss.com/bootstrap-table/1.11.1/bootstrap-table.min.css" rel="stylesheet">


<script src="https://cdn.bootcss.com/jquery/2.2.3/jquery.min.js">script>
<script src="https://cdn.bootcss.com/bootstrap/3.3.6/js/bootstrap.min.js">script>


<script src="https://cdn.bootcss.com/bootstrap-table/1.11.1/bootstrap-table.min.js">script>

<script src="https://cdn.bootcss.com/bootstrap-table/1.11.1/locale/bootstrap-table-zh-CN.min.js">script>

<html>
<head>
    <title>Titletitle>
head>
<body>
<script type="text/javascript">
    function initTable() {
        //初始化表格,动态从服务器加载数据
        $("#cusTable").bootstrapTable({
            method: "get",  //使用get请求到服务器获取数据
            url: "/getsecondall.action", //获取数据的Servlet地址
            toolbar: '#toolbar',                //工具按钮用哪个容器
            pagination: true, //启动分页
            pageSize: 10,  //每页显示的记录数
            pageNumber:1, //当前第几页
            pageList: [5, 10, 15, 20, 25],  //记录数可选列表
            search: false,  //是否启用查询
            showColumns: true,  //显示下拉框勾选要显示的列
            showRefresh: true,  //显示刷新按钮
            sidePagination: "server", //表示服务端请求
            height: 500,                        //行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度
            uniqueId: "pid",                     //每一行的唯一标识,一般为主键列
            showToggle:true,                    //是否显示详细视图和列表视图的切换按钮
            cardView: false,                    //是否显示详细视图
            detailView: false,                   //是否显示父子表
            minimumCountColumns: 2,             //最少允许的列数
            clickToSelect: true,                //是否启用点击选中行
            //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder
            //设置为limit可以获取limit, offset, search, sort, order
            queryParamsType : "undefined",
            queryParams: function queryParams(params) {   //设置查询参数
                var param = {
                    pageNumber: params.pageNumber,
                    pageSize: params.pageSize,
                    orderNum : $("#txt_search_departmentname").val(),
                    page:$("#txt_search_statu").val()
                };
                return param;
            },
            columns: [{
                checkbox: true
            }, {
                field: 'pname',
                title: '名称'
            }, {
                field: 'page',
                title: '年龄'
            }, {
                field: 'pid',
                title: 'id'
            }, ]

        });
    }

    $(document).ready(function () {
        //调用函数,初始化表格
        initTable();

        //当点击查询按钮的时候执行
        $("#btn_query").bind("click", initTable);

        //删除
        $('#btn_delete').on("click", function () {
            var row=$.map($("#cusTable").bootstrapTable('getSelections'),function(row){
                return row ;
            });
            var ids=[];
            for (var i = 0; i < row.length; i++) {
                //获取自定义table 的中的checkbox值
                var id=row[i].pid;   //OTRECORDID这个是你要在列表中取的单个id
                ids.push(id); //然后把单个id循环放到ids的数组中
            }
            var str=JSON.stringify(ids);
             //批量删除:
            $.ajax({
                type:"POST",
                url:"/delPerson.action",
                data:"str="+str,
                success:function(msg){
                    // alert("返回的是:"+msg);
                    if(msg==1){
                       // alert("删除成功!");
                        $('#cusTable').bootstrapTable('refresh');
                    }else{
                        alert("删除失败!");
                    }
                }
            });
        });

        //添加:
        $('#btn_add').on("click", function () {
            $('#myModal').modal();
        });

        //修改
        $('#btn_edit').on("click", function () {

            var row=$.map($("#cusTable").bootstrapTable('getSelections'),function(row){
                return row ;
            });
            if(row.length==1){
                for (var i = 0; i < row.length; i++) {
                    alert(row[i].pid);
                    //打开弹出框:
                    $('#updatemyModal').modal();
                    $('#updatepname').val(row[i].pname);
                    $('#updatepage').val(row[i].page);
                }
            }
        });


    })

//提交添加:
    function mya(){
        var addpname=$('#addpname').val();
        var addpage=$('#addpage').val();
        //实例化一个对象:
        var person={"pname":addpname,"page":addpage};
        //将对象转换成字符串
        var str=JSON.stringify(person);
        alert(str);
        $.ajax({
            type:"POST" ,
            url:"/addPerson.action",
            data:"str="+str,
            success:function(msg){
                if(msg==1){
                    $('#cusTable').bootstrapTable('refresh');
                    $('#ff_p').form('clear');
                }else{
                    alert('添加失败');
                }

            }
        });
    }

    //修改提交:
    function myb(){
        var addpname=$('#updatepname').val();
        var addpage=$('#updatepage').val();
        //实例化一个对象:
        var person={"pname":addpname,"page":addpage};
        //将对象转换成字符串
        var str=JSON.stringify(person);
        $.ajax({
            type:"POST" ,
            url:"/addPerson.action",
            data:"str="+str,
            success:function(msg){
                if(msg==1){
                    $('#cusTable').bootstrapTable('refresh');
                }else{
                    alert('修改失败');
                }

            }
        });
    }

script>

<div class="panel-body" style="padding-bottom:0px;">
    <div class="panel panel-default">
        <div class="panel-heading">查询条件div>
        <div class="panel-body">
            <form id="formSearch" class="form-horizontal">
                <div class="form-group" style="margin-top:15px">
                    <label class="control-label col-sm-1" for="txt_search_departmentname">姓名label>
                    <div class="col-sm-3">
                        <input type="text" class="form-control" id="txt_search_departmentname">
                    div>
                    <label class="control-label col-sm-1" for="txt_search_statu">年龄label>
                    <div class="col-sm-3">
                        <input type="text" class="form-control" id="txt_search_statu">
                    div>
                    <div class="col-sm-4" style="text-align:left;">
                        <button type="button" οnclick="mya()" id="btn_query" class="btn btn-primary">查询button>
                    div>
                div>
            form>
        div>
    div>

    <div id="toolbar" class="btn-group">
        <button id="btn_add" type="button" class="btn btn-default">
            <span class="glyphicon glyphicon-plus" aria-hidden="true">span>新增
        button>
        <button id="btn_edit" type="button" class="btn btn-default">
            <span class="glyphicon glyphicon-pencil" aria-hidden="true">span>修改
        button>
        <button id="btn_delete" type="button" class="btn btn-default">
            <span class="glyphicon glyphicon-remove" aria-hidden="true">span>删除
        button>
    div>

    <table class="table table-hover" id="cusTable">
    table>
div>

<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
    <div class="modal-dialog" role="document">
        <div class="modal-content">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×span>button>
                <h4 class="modal-title" id="myModalLabel">新增h4>
            div>
            <div class="modal-body">
                <form id="ff_p" method="post">
                    <div class="form-group">
                        <label for="addpname">姓名label>
                        <input type="text" name="namepname" class="form-control" id="addpname" placeholder="姓名">
                    div>

                    <div class="form-group">
                        <label for="addpage">年龄label>
                        <input type="text" name="namepid" class="form-control" id="addpage" placeholder="年龄">
                    div>
                    <div class="modal-footer">
                        <button type="button" class="btn btn-default" data-dismiss="modal"><span class="glyphicon glyphicon-remove" aria-hidden="true">span>关闭button>
                        <button type="button" id="btn_submit" class="btn btn-primary" data-dismiss="modal" οnclick="mya()"><span class="glyphicon glyphicon-floppy-disk" aria-hidden="true" >span>保存button>
                    div>
                form>
            div>
        div>
    div>
div>

<div class="modal fade" id="updatemyModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
    <div class="modal-dialog" role="document">
        <div class="modal-content">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×span>button>
                <h4 class="modal-title" id="updatemyModalLabel">修改h4>
            div>
            <div class="modal-body">
                <form id="updateff_p" method="post">
                    <div class="form-group">
                        <label for="updatepname">姓名label>
                        <input type="text" name="namepname" class="form-control" id="updatepname" placeholder="姓名">
                    div>

                    <div class="form-group">
                        <label for="updatepage">年龄label>
                        <input type="text" name="namepid" class="form-control" id="updatepage" placeholder="年龄">
                    div>
                    <div class="modal-footer">
                        <button type="button" class="btn btn-default" data-dismiss="modal"><span class="glyphicon glyphicon-remove" aria-hidden="true">span>关闭button>
                        <button type="button" id="btn_update" class="btn btn-primary" data-dismiss="modal" οnclick="myb()"><span class="glyphicon glyphicon-floppy-disk" aria-hidden="true" >span>保存button>
                    div>
                form>
            div>
        div>
    div>
div>

body>
html>

最后,附上一个完整截图:

Bootstrap+spring+springmvc+mybatis实现基本的增删改查(源码)_第2张图片


你可能感兴趣的:(Bootstrap+spring+springmvc+mybatis实现基本的增删改查(源码))