山海关古城信息管理测试--片区

实现要求

1.片区的检验名称编号是否重复

1.1controller添加两个方法,检验片区编号和检验片区名称

        作用为:调用方法判断片区编号与片区名称是否重复,并返回返回值

 
    /**
     * 检验片区编号是否重复
     */
    @PostMapping( "/checkPqbhUnique")
    @ResponseBody
    public String checkXqbhUnique(TBxwPqZhk tBxwPqZhk){
    	String back = tBxwPqZhkService.checkPqbhUnique(tBxwPqZhk.getId(),tBxwPqZhk.getPqbh());
        return back;
    }
    
    /**
     * 校验片区名称是否重复
     */
    @PostMapping("/checkPqmcUnique")
    @ResponseBody
    public String checkXqmcUnique(TBxwPqZhk tBxwPqZhk){
    	String back = tBxwPqZhkService.checkPqmcUnique(tBxwPqZhk.getId(),tBxwPqZhk.getPqmc());
        return back;
    }

1.2添加service和mapper中方法

        service:

 /**
     * 检验片区编号是否重复
     *
     * @param id 片区主键 
     * @param pqbh 片区编号
     * @return 结果
     */
	public String checkPqbhUnique(String id, String pqbh);

    /**
     * 检验片区编号是否重复
     *
     * @param id 片区主键 
     * @param pqmc 片区名称
     * @return 结果
     */
	public String checkPqmcUnique(String id, String pqmc);

        serviceImp:


    /**
     * 检验片区编号是否重复
     *
     * @param id 片区主键 
     * @param pqbh 片区编号
     * @return 0表示唯一,1表示重复
     */
	@Override
	public String checkPqbhUnique(String id, String pqbh) {
		// TODO Auto-generated method stub
		if (id != null && id.length() != 0) {
    	}else {
    		id = "1";
    	}
    	Map <String , String> map = new HashMap <String , String> ();
        map.put("id", id);
        map.put("pqbh", pqbh);
    	
        int count = tBxwPqZhkMapper.checkPqbhUnique(map);
        if (count > 0)
        {
           return "1";
        }
        return "0";
	}

	 /**
     * 检验片区名称是否重复
     *
     * @param id 片区主键 
     * @param pqmc 片区名称
     * @return 0表示唯一,1表示重复
     */
	@Override
	public String checkPqmcUnique(String id, String pqmc) {
		// TODO Auto-generated method stub
		if (id != null && id.length() != 0) {
    	}else {
    		id = "1";
    	}
    	Map <String , String> map = new HashMap <String , String> ();
        map.put("id", id);
        map.put("pqmc", pqmc);
    	
        int count = tBxwPqZhkMapper.checkPqmcUnique(map);
        if (count > 0)
        {
           return "1";
        }
        return "0";
	}

        mapper:

    /**
     * 校验片区编号是否唯一
     * 
     * @param Map id:片区编号  pqbh:片区名称
     * @return 结果
     */
    public int checkPqbhUnique(java.util.Map Map);
    
    /**
     * 校验片区编号是否唯一
     * 
     * @param Map id:片区编号  pqmc:片区名称
     * @return 结果
     */
    public int checkPqmcUnique(java.util.Map Map);

1.3添加mapper.xml文件方法

        添加对应函数的连接数据库方法:

	
	<select id="checkPqbhUnique" parameterType="java.util.Map" resultType="int">
		select count(1) from t_bxw_pq_zhk where id != #{id} and pqbh=#{pqbh} and rownum <![CDATA[ <= ]]> 1
	</select>
	
	<select id="checkPqmcUnique" parameterType="java.util.Map" resultType="int">
		select count(1) from t_bxw_pq_zhk where id != #{id} and pqmc=#{pqmc} and rownum <![CDATA[ <= ]]> 1
	</select>

1.4修改add.html中代码,加入对应代码模块

        注意前面需要加入id=''pqbh'' 和id="pqmc",否则代码功能不实现!!!

  <th:block th:include="include :: footer" />
    <script th:inline="javascript">
        var prefix = ctx + "jcxx/pq"
        $("#form-pq-add").validate({
    	//数据校验
     	onkeyup: false,
    	rules:{
    		pqbh:{
       			minlength: 2,
       			maxlength: 20,
       			digits:true,
       			remote: {
	                url: prefix + "/checkPqbhUnique",
	                type: "post",
	                dataType: "json",
                    data: {
                    	"id": function() {
                         	return $("#id").val();
                     	},
                    	"pqbh": function() {	          
                            return $.common.trim($("#pqbh").val());
                        }
                    },
                    dataFilter: function(data, type) {
                    	return $.validate.unique(data);
                    }
               	}
   			},
   			pqmc:{
       			remote: {
	                url: prefix + "/checkPqmcUnique",
	                type: "post",
	                dataType: "json",
                    data: {
                    	"id": function() {
                         	return $("#id").val();
                     	},
                    	"pqmc": function() {
                            return $.common.trim($("#pqmc").val());
                        }
                    },
                    dataFilter: function(data, type) {
                    	return $.validate.unique(data);
                    }
               	}
   			}
    	},
    	messages: {
            "pqbh": {
                remote: "片区编号已经存在!"
            },
            "pqmc": {
                remote: "片区名称已经存在!"
            }
        },
        focusCleanup: true
    });
    
        function submitHandler() {
            if ($.validate.form()) {
                $.operate.save(prefix + "/add", $('#form-pq-add').serialize());
            }
        }
    </script>

        编辑功能中的重复信息提示也一样,修改edit.html即可,与pq.html一致

1.5功能实现

2.按序排列

2.1法一:在pq.html中加入sort语句

2.2功能实现

        按照默认值片区编号进行排序

2.3法二:在pq.html中加入sort语句

2.4功能实现

        可以通过点击红框处进行对应的升序或降序排序

3.片区删除时,输出提示框,若存在子街道,则不能删除

3.1连接片区表和街道表

3.1.1分析二者关系,修改domain文件

        一个片区可以有多个街道,一个街道属于一个片区,所以片区与街道是一对多的关系。

        因此需要在街道的属性domain中加入片区属性,正常情况下加入片区属性TBxwPq最好,但是为了代码的简易及基本的功能的实现,本代码中只加入了片区id(外键,原本就有的)和片区名称(pqmc),并生成对应的get和set方法。

3.1.2修改街道的xml文件

        在原有基础上加入片区名称(pqmc)的属性,并微调sql语句,由单表查询变为多表查询

3.1.3修改街道html文件

        将原来的片区id修改为片区名称即可。在添加和修改时,在片区中多几处细微的修改

        jd.html

<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
    <th:block th:include="include :: header('片区街道列表')" />
</head>
<body class="gray-bg">
     <div class="container-div">
        <div class="row">
            <div class="col-sm-12 search-collapse">
                <form id="formId">
                    <div class="select-list">
                        <ul>
                            <li>
                                <label>片区名称:</label>
                              	<input type="text" name="pqmc"/>
                            </li>
                            <li>
                                <label>街道编号:</label>
                                <input type="text" name="jdbh"/>
                            </li>
                            <li>
                                <label>街道名称:</label>
                                <input type="text" name="jdmc"/>
                            </li>
                            <li>
                                <label>注销标志:</label>
                                <select name="zxbz" th:with="type=${@dict.getType('t_jc_zxztlx')}">
                                    <option value="">所有</option>
                                    <option th:each="dict : ${type}" th:text="${dict.dictLabel}" th:value="${dict.dictValue}"></option>
                                </select>
                            </li>
                        
                            <li>
                                <a class="btn btn-primary btn-rounded btn-sm" onclick="$.table.search()"><i class="fa fa-search"></i>&nbsp;搜索</a>
                                <a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i class="fa fa-refresh"></i>&nbsp;重置</a>
                            </li>
                        </ul>
                    </div>
                </form>
            </div>

            <div class="btn-group-sm" id="toolbar" role="group">
                <a class="btn btn-success" onclick="$.operate.add()" shiro:hasPermission="jcxx:jd:add">
                    <i class="fa fa-plus"></i> 添加
                </a>
                <a class="btn btn-primary single disabled" onclick="$.operate.edit()" shiro:hasPermission="jcxx:jd:edit">
                    <i class="fa fa-edit"></i> 修改
                </a>
                <a class="btn btn-danger multiple disabled" onclick="$.operate.removeAll()" shiro:hasPermission="jcxx:jd:remove">
                    <i class="fa fa-remove"></i> 删除
                </a>
                <a class="btn btn-warning" onclick="$.table.exportExcel()" shiro:hasPermission="jcxx:jd:export">
                    <i class="fa fa-download"></i> 导出
                </a>
            </div>
            <div class="col-sm-12 select-table table-striped">
                <table id="bootstrap-table"></table>
            </div>
        </div>
    </div>
    <th:block th:include="include :: footer" />
    <script th:inline="javascript">
        var editFlag = [[${@permission.hasPermi('jcxx:jd:edit')}]];
        var removeFlag = [[${@permission.hasPermi('jcxx:jd:remove')}]];
        var zxbzDatas = [[${@dict.getType('t_jc_zxztlx')}]];
        var prefix = ctx + "jcxx/jd";

        $(function() {
            var options = {
                url: prefix + "/list",
                createUrl: prefix + "/add",
                updateUrl: prefix + "/edit/{id}",
                removeUrl: prefix + "/remove",
                exportUrl: prefix + "/export",
                modalName: "片区街道",
                columns: [{
                    checkbox: true
                },
                {
                    field: 'id',
                    title: '主键',
                    visible: false
                },
                {
                    field: 'pqmc',
                    title: '片区名称'
                },
                {
                    field: 'jdbh',
                    title: '街道编号'
                },
                {
                    field: 'jdmc',
                    title: '街道名称'
                },
                {
                    field: 'zxbz',
                    title: '注销标志',
                    formatter: function(value, row, index) {
                       return $.table.selectDictLabel(zxbzDatas, value);
                    }
                },
                {
                    field: 'bz',
                    title: '备注'
                },
                
                {
                    title: '操作',
                    align: 'center',
                    formatter: function(value, row, index) {
                        var actions = [];
                        actions.push('<a class="btn btn-success btn-xs ' + editFlag + '" href="javascript:void(0)" onclick="$.operate.edit(\'' + row.id + '\')"><i class="fa fa-edit"></i>编辑</a> ');
                        actions.push('<a class="btn btn-danger btn-xs ' + removeFlag + '" href="javascript:void(0)" onclick="$.operate.remove(\'' + row.id + '\')"><i class="fa fa-remove"></i>删除</a>');
                        return actions.join('');
                    }
                }]
            };
            $.table.init(options);
        });
    </script>
</body>
</html>

        add.html

<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" >
<head>
    <th:block th:include="include :: header('新增片区街道')" />
</head>
<body class="white-bg">
    <div class="wrapper wrapper-content animated fadeInRight ibox-content">
        <form class="form-horizontal m" id="form-jd-add">
            <div class="form-group">    
                <label class="col-sm-3 control-label is-required" >片区:</label>
                <div class="col-sm-8">
                      <select id="pq" name="tBxwPqZhkId" class="form-control select2-single required" single>
						  <option th:each="pq:${pqs}" th:value="${pq.id}" th:text="${pq.pqmc}" ></option>
					  </select>
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label is-required">街道编号:</label>
                <div class="col-sm-8">
                    <input name="jdbh" class="form-control" type="text" required>
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label is-required">街道名称:</label>
                <div class="col-sm-8">
                    <input name="jdmc" class="form-control" type="text" required>
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label is-required">注销标志:</label>
                <div class="col-sm-8">
                    <select name="zxbz" class="form-control m-b" th:with="type=${@dict.getType('t_jc_zxztlx')}" required>
                        <option th:each="dict : ${type}" th:text="${dict.dictLabel}" th:value="${dict.dictValue}"></option>
                    </select>
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label">备注:</label>
                <div class="col-sm-8">
                    <input name="bz" class="form-control" type="text">
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label">扩展1:</label>
                <div class="col-sm-8">
                    <input name="kz1" class="form-control" type="text">
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label">扩展2:</label>
                <div class="col-sm-8">
                    <input name="kz2" class="form-control" type="text">
                </div>
            </div>
        </form>
    </div>
    <th:block th:include="include :: footer" />
    <script th:inline="javascript">
        var prefix = ctx + "jcxx/jd"
        $("#form-jd-add").validate({
            focusCleanup: true
        });

        function submitHandler() {
            if ($.validate.form()) {
                $.operate.save(prefix + "/add", $('#form-jd-add').serialize());
            }
        }
    </script>
</body>
</html>

        edit.html

<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" >
<head>
    <th:block th:include="include :: header('修改片区街道')" />
</head>
<body class="white-bg">
    <div class="wrapper wrapper-content animated fadeInRight ibox-content">
        <form class="form-horizontal m" id="form-jd-edit" th:object="${tBxwPqJdZhk}">
            <input name="id" th:field="*{id}" type="hidden">
            <div class="form-group">    
                <label class="col-sm-3 control-label is-required" >片区:</label>
                <div class="col-sm-8">
                      <select id="pq" name="tBxwPqZhkId" class="form-control select2-single required" single>
						  <option th:each="pq:${pqs}" th:value="${pq.id}" th:text="${pq.pqmc}" ></option>
					  </select>
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label is-required">街道编号:</label>
                <div class="col-sm-8">
                    <input name="jdbh" th:field="*{jdbh}" class="form-control" type="text" required>
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label is-required">街道名称:</label>
                <div class="col-sm-8">
                    <input name="jdmc" th:field="*{jdmc}" class="form-control" type="text" required>
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label is-required">注销标志:</label>
                <div class="col-sm-8">
                    <select name="zxbz" class="form-control m-b" th:with="type=${@dict.getType('t_jc_zxztlx')}" required>
                        <option th:each="dict : ${type}" th:text="${dict.dictLabel}" th:value="${dict.dictValue}" th:field="*{zxbz}"></option>
                    </select>
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label">备注:</label>
                <div class="col-sm-8">
                    <input name="bz" th:field="*{bz}" class="form-control" type="text">
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label">扩展1:</label>
                <div class="col-sm-8">
                    <input name="kz1" th:field="*{kz1}" class="form-control" type="text">
                </div>
            </div>
            <div class="form-group">    
                <label class="col-sm-3 control-label">扩展2:</label>
                <div class="col-sm-8">
                    <input name="kz2" th:field="*{kz2}" class="form-control" type="text">
                </div>
            </div>
        </form>
    </div>
    <th:block th:include="include :: footer" />
    <script th:inline="javascript">
        var prefix = ctx + "jcxx/jd";
        $("#form-jd-edit").validate({
            focusCleanup: true
        });

        function submitHandler() {
            if ($.validate.form()) {
                $.operate.save(prefix + "/edit", $('#form-jd-edit').serialize());
            }
        }
    </script>
</body>
</html>

3.1.4新建片区service方法

        在街道的添加中,必须要已知现有的全部正常的片区,然后才可以在该片区下新建街道,而由于源代码中并未有函数方法能够完成这一操作,所以需要在pq中新建一个方法    selectTBxwPqZhkAll()  通过sql语句的修改,进行显示全部片区。

        service:

        serviceImp:

        mapper:

        mapper.xml:

3.1.5修改街道的controller中的add

3.1.6功能实现

        正确显示片区名称:

        回显全部片区:

3.2实现删除功能

3.2.1修改片区的serviceImp中删除函数的具体实现

package com.xyt.project.shggc.jcxx.pq.service.impl;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.xyt.project.shggc.jcxx.pq.mapper.TBxwPqZhkMapper;
import com.xyt.project.shggc.jcxx.jd.mapper.TBxwPqJdZhkMapper;
import com.xyt.project.shggc.jcxx.pq.domain.TBxwPqZhk;
import com.xyt.project.shggc.jcxx.pq.service.ITBxwPqZhkService;
import com.xyt.common.utils.text.Convert;
import com.xyt.common.exception.BusinessException;

/**
 * 片区Service业务层处理
 *
 * @author ruoyi
 * @date 2024-08-05
 */
@Service
@Transactional(rollbackFor = Exception.class)
public class TBxwPqZhkServiceImpl implements ITBxwPqZhkService
{
    @Autowired
    private TBxwPqZhkMapper tBxwPqZhkMapper;

    @Autowired
    private TBxwPqJdZhkMapper tBxwPqJdZhkMapper;

    /**
     * 查询片区
     *
     * @param id 片区主键
     * @return 片区
     */
    @Override
    public TBxwPqZhk selectTBxwPqZhkById(String id)
    {
        return tBxwPqZhkMapper.selectTBxwPqZhkById(id);
    }

    /**
     * 查询片区列表
     *
     * @param tBxwPqZhk 片区
     * @return 片区
     */
    @Override
    public List<TBxwPqZhk> selectTBxwPqZhkList(TBxwPqZhk tBxwPqZhk)
    {
        return tBxwPqZhkMapper.selectTBxwPqZhkList(tBxwPqZhk);
    }
    
	 /**
     * 查询全部片区信息
     *
     */
	@Override
	public List<TBxwPqZhk> selectTBxwPqZhkAll() {
		// TODO Auto-generated method stub
		return tBxwPqZhkMapper.selectTBxwPqZhkAll();
	}
	
    /**
     * 新增片区
     *
     * @param tBxwPqZhk 片区
     * @return 结果
     */
    @Override
    public int insertTBxwPqZhk(TBxwPqZhk tBxwPqZhk)
    {
        return tBxwPqZhkMapper.insertTBxwPqZhk(tBxwPqZhk);
    }

    /**
     * 修改片区
     *
     * @param tBxwPqZhk 片区
     * @return 结果
     */
    @Override
    public int updateTBxwPqZhk(TBxwPqZhk tBxwPqZhk)
    {
        return tBxwPqZhkMapper.updateTBxwPqZhk(tBxwPqZhk);
    }

    /**
	 * 批量删除片区
     *
	 * @param ids 需要删除的片区主键
     * @return 结果
     */
    @Override
    public int deleteTBxwPqZhkByIds(String ids)
    {
    	String[] iids = Convert.toStrArray(ids);
        for (String id : iids)
        {
        	TBxwPqZhk tBxwPqZhk = selectTBxwPqZhkById(id);
            int pqjdNum = tBxwPqJdZhkMapper.selectTBxwPqJdZhkByPqId(tBxwPqZhk.getId()).size();
            if (pqjdNum > 0)
            {
                throw new BusinessException(String.format("%1$s下已经有街道信息,不能删除", tBxwPqZhk.getPqmc()));
            }
        }
        return tBxwPqZhkMapper.deleteTBxwPqZhkByIds(Convert.toStrArray(ids));
    }

    /**
     * 删除片区信息
     *
     * @param id 片区ID
     * @return 结果
     */
    @Override
    public int deleteTBxwPqZhkById(String id)
    {
    	//通过片区id查询出该片区
    	TBxwPqZhk tBxwPqZhk = selectTBxwPqZhkById(id);
    	/通过调用函数selectTBxwPqJdZhkByPqId搜索出有多少个街道的片区id为上id,并计入到pqjdNum中
        int pqjdNum = tBxwPqJdZhkMapper.selectTBxwPqJdZhkByPqId(tBxwPqZhk.getId()).size();
    	/如果片区街道数大于0,则说明该片区存在子街道,不能删除
        if (pqjdNum > 0)
        {
            throw new BusinessException(String.format("%1$s下已经有街道信息,不能删除", tBxwPqZhk.getPqmc()));
        }
        如果为0,成功删除
        return tBxwPqZhkMapper.deleteTBxwPqZhkById(id);
    }
    

    /**
     * 检验片区编号是否重复
     *
     * @param id 片区主键 
     * @param pqbh 片区编号
     * @return 0表示唯一,1表示重复
     */
	@Override
	public String checkPqbhUnique(String id, String pqbh) {
		// TODO Auto-generated method stub
		if (id != null && id.length() != 0) {
    	}else {
    		id = "1";
    	}
    	Map <String , String> map = new HashMap <String , String> ();
        map.put("id", id);
        map.put("pqbh", pqbh);
    	
        int count = tBxwPqZhkMapper.checkPqbhUnique(map);
        if (count > 0)
        {
           return "1";
        }
        return "0";
	}

	 /**
     * 检验片区名称是否重复
     *
     * @param id 片区主键 
     * @param pqmc 片区名称
     * @return 0表示唯一,1表示重复
     */
	@Override
	public String checkPqmcUnique(String id, String pqmc) {
		// TODO Auto-generated method stub
		if (id != null && id.length() != 0) {
    	}else {
    		id = "1";
    	}
    	Map <String , String> map = new HashMap <String , String> ();
        map.put("id", id);
        map.put("pqmc", pqmc);
    	
        int count = tBxwPqZhkMapper.checkPqmcUnique(map);
        if (count > 0)
        {
           return "1";
        }
        return "0";
	}


}

3.2.2在街道的mapper文件中加入selectTBxwPqJdZhkByPqId方法

        

        在街道的mapper.xml中具体实现:

3.2.3功能实现

        提示框输出,防止误触:

        存在子街道,拒绝删除:

  • 11
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值