java实现删除某条信息并刷新当前页操作
作者:我相信慢思考的力量 发布时间:2022-06-26 07:12:12
标签:java,删除,信息,刷新
我就废话不多说了,大家还是直接看代码吧~
//执行的是删除信息的操作
String a=request.getParameter("name");
a = URLEncoder.encode(a, "ISO-8859-1");
String name = URLDecoder.decode(a, "UTF-8");
String num=request.getParameter("num");
System.out.println("name:"+name+"num:"+num);
String sql="delete from person_info where name=? and num=?";
String sz[]={name,num};
JdbcUtils.update(sql, sz);
//刷新操作
String sqls="select * from person_info";
ResultSet rs=JdbcUtils.select(sqls, null);
ArrayList<Person_info> list=new ArrayList<Person_info>();
try {
while(rs.next()){
Person_info pi=new Person_info(rs.getString(1), rs.getString(2), rs.getString(3), rs.getString(4), rs.getString(5), rs.getString(6));
list.add(pi);
}
request.setAttribute("list", list);
request.getRequestDispatcher("Personnel_definition.jsp").forward(request, response);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
补充知识:关于分页时怎么实现当本页面最后一条记录被删除时,自动向上一个页面跳转的实现(java实现)
##问题详解
在做批量删除时,发现若批量删除整页时,会自动跳到第一页首页,而不是返回删除当前页的上一页,不符合产品要求且使界面交互不好,给用户带来糟糕体验。
##思路详解
在controller层传参时要考虑到不仅要传入需要删除的id集合,同时传入pageSize,pageNum以及总条数集合的查询条件(如:本示例会传入groupId(分组id)),在删除成功后初始化当前页,先根据查询条件查询出总条数数量,在pageSize不等于null或为0的情况下。算出余数[(pageSize*pageNum-count)%pageSize ].若余数为0,则当前页等于pageNum-1;若余数不为0,则当前页=pageNum.将结果当前页传给前台即可。
##后台代码实现
#controller层#
@Api(description = "分组下的学生",value = "分组下的学生")
@RestController
@RequestMapping("studentGroup")
public class StudentGroupController {
@Autowired
private RestStudentGroupService restStudentGroupService;
@RequestMapping(value = "deleteGroupStudent",method = RequestMethod.POST)
@ApiOperation(value = "删除分组中的学生",notes = "删除分组中的学生")
public ResponseObj deleteGroupStudent(@RequestParam(value = "groupId",required = true)Long groupId,
@RequestParam(value = "ids",required = true)String ids,
@RequestParam(value = "pageSize",required = false)Integer pagesize,
@RequestParam(value = "pageNum",required = false)Integer pageNum){
return restStudentGroupService.deleteGroupStudent(groupId,ids,pagesize,pageNum);
}
}
#service层#
@FeignClient(value = ServiceName.VALUE)
public interface RestStudentGroupService {
@RequestMapping(value = "/school/cloud/student/deleteGroupStudent",method = RequestMethod.POST)
public ResponseObj deleteGroupStudent(@RequestParam(value = "groupId")Long groupId,
@RequestParam(value = "ids")String ids,
@RequestParam(value = "pageSize")Integer pagesize,
@RequestParam(value = "pageNum")Integer pageNum);
}
#serviceImpl层#
@Service
public class RestStudentGroupServiceImpl implements RestStudentGroupService {
@Autowired
private DubboStudentGroupService dubboStudentGroupService ;
@Override
public ResponseObj deleteGroupStudent(Long groupId,String ids,Integer pageSize,Integer pageNum) {
List<Long> idList = TextUtils.split(ids);
if(groupId == null || idList== null || idList.size() == 0){
ResponseObj responseObj = ResponseObj.ERROR("参数错误");
responseObj.setSuccess(true);
return responseObj;
}
ServiceResult<Long> serviceResult = dubboStudentGroupService .deleteCorpGroup(idList, groupId);
if(!serviceResult.getSuccess()){
throw new RuntimeException("分组下学生查询失败");
}
//应前端要求加此dto,封装传给前台的当前页属性
CurrenPageDto currenPageDto=new CurrenPageDto();
//初始化当前页
Integer currentPage = 1;
//查出该分组id下的学生数量
ServiceResult<Long> itemCountLongs = dubboStudentGroupService.getTotalCount(groupId);
Long itemCountLong= itemCountLongs.getResult();
Integer itemCount = itemCountLong!=null ? itemCountLong.intValue() : 0;
//"查询到学生数量:{},pageSize:{}", itemCount,pageSize;
if(pageSize != null && pageSize != 0){
//算出余数
Integer temp = (pageNum*pageSize-itemCount)%pageSize;
if(temp == 0){
//余数为0的话就pageNum-1
currentPage = (pageNum - 1) == 0 ? 1 : (pageNum -1) ;
}else {
//余数不为0则等于pageNum
currentPage = pageNum;
}
currenPageDto.setPresentPage(currentPage);
}
ResponseObj responseObj = ResponseObj.SUCCESS();
responseObj.setData(currenPageDto);
return responseObj;
}
}
#dubbo接口的service层#
①://删除分组下的学生
ServiceResult<Long> deleteCorpGroup(List<Long> idList,Long groupId);
②://根据条件查询对应的条目总数
ServiceResult<Long> getTotalCount(Long groupId);
#dubbo接口的serviceImpl层#
①://删除分组下的学生
@Override
public ServiceResult<Long> deleteCorpGroup(List<Long> idList, Long groupId) {
ServiceResult<Long> result = new ServiceResult<>();
try {
studentGroupDao.deleteCorpGroup(idList, groupId);
} catch (Exception e) {
log.error("调用{}方法 异常", "[RestStudentGroupServiceImpl .deleteCorpGroup]");
log.error("方法使用参数:[idList:{},groupId:{}]", idList, groupId);
log.error("异常信息:{}", e);
result.setErrMessage("调用deleteCorpGroup方法异常,异常信息:" + e.getMessage());
}
return result;
}
②://根据条件查询对应的条目总数
@Override
public ServiceResult<Long> getTotalCount(Long groupId) {
ServiceResult<Long> result = new ServiceResult<>();
try {
long count = studentGroupDao.getFindCorpGroupDirectoryCount(groupId);
result.setResult(count);
} catch (Exception e) {
log.error("调用{}方法 异常", "[RestStudentGroupServiceImpl .getTotalCount]");
log.error("方法使用参数:[groupId:{}]", groupId);
log.error("异常信息:{}", e);
result.setErrMessage("调用getTotalCount方法异常,异常信息:" + e.getMessage());
}
return result;
}
#dubbo接口的dao层#
①://删除分组下的学生
Long deleteCorpGroup(@Param(value = "idList") List<Long> idList,@Param(value = "groupId") Long groupId);
②://根据条件查询对应的条目总数
Long getFindCorpGroupDirectoryCount(@Param(value = "groupId") Long groupId);
#dubbo接口的sql#
①://删除分组下的学生
<delete id="deleteCorpGroup">
delete from student_group where group_id = #{groupId} and id in
<foreach collection="idList" index="index" separator="," item="id"
open="(" close=")">
#{id}
</foreach>
</delete>
②://根据条件查询对应的条目总数
<select id="getFindCorpGroupDirectoryCount" resultType="long">
SELECT COUNT(1)
FROM student_group
where group_id = #{groupId}
</select>
#Entity类(学生分组类)#(get,set函数省略)
public class StudentGroup implements java.io.Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
/**
* @描述:
* @字段:id BIGINT(19)
*/
private Long StudentGroupId;
/**
* @描述:
* @字段:group_id BIGINT(19)
*/
private Long groupId;
/**
* @描述:
* @字段:id BIGINT(19)
* 此id为学生表id
*/
private Long id;
/**
* @描述:创建时间
* @字段:create_time DATETIME(19)
*/
private java.util.Date createTime;
* @描述:创建人用户名
* @字段:create_user_name VARCHAR(30)
*/
private String createUserName;
/**
* @描述:创建人用户ID
* @字段:create_user_id BIGINT(19)
*/
private Long createUserId;
/**
* @描述:更新时间
* @字段:update_time DATETIME(19)
*/
private java.util.Date updateTime;
* @描述:更新人用户名
* @字段:update_user_name VARCHAR(30)
*/
private String updateUserName;
/**
* @描述:更新人用户ID
* @字段:update_user_id BIGINT(19)
*/
private Long updateUserId;
}
#Entity类(学生类)#(get,set函数省略)
public class Student implements java.io.Serializable {
/**
*
*/
private static final long serialVersionUID = 1L;
private Long id;
private String name ;
private Integer age;
}
来源:https://blog.csdn.net/qq_37591637/article/details/82770918


猜你喜欢
- 流,就是一系列的数据。当不同介质之间有数据交互的时候,JAVA就使用流来实现。数据源可以是文件,还可以是数据库、网络甚至其他的程序。比如读取
- 前言在上一篇 Spring boot + LayIM + t-io 文件上传、 监听用户状态的实现 中,已经介绍了两个小细节:用户的在离线状
- JavaWeb登录界面登录失败在同一页面进行提示方法使用JSP 通过提交表单方式 判断账号密码是否正确 不正确则调用req.setAttri
- 手机一般有两种类型的输入设备。一种是键盘类型的输入设备,通常它包含电源键和音量下键。另一种是触摸类型的输入设备,触摸屏就属于这种类型。键盘类
- 了解过spring-Boot这个技术的,应该知道Spring-Boot的核心配置文件application.properties,当然也可以
- 前言在web开发过程中涉及到表格时,例如dataTable,就会产生分页的需求,通常我们将分页方式分为两种:前端分页和后端分页。前端分页一次
- 最近在鼓捣spring -boot ,真好用,学习到jpa.通过生成Entity 文件,能够快速的生成数据库,并且使用JpaReposito
- spring-data-redis项目  spring-data-redis提供了在Spring应用中通
- 废话不多说了,直接给大家贴代码,具体代码如下所示://打开Excel文件,转换为DataTable DataTable dtExcel;pr
- 前言当系统的并发比较高的时候,日志的处理输出也是一种性能的开销负担,所以,选择一个中间件来处理消费日志必不可少!下面是spring boot
- 目录:DioManager:Dio辅助类NWMethod:请求方法,get、post等NWApi:大家都知道EntityFactory:js
- 1、获取视频缩略图有两个方法(1)通过内容提供器来获取(2)人为创建缩略图(1)缺点就是必须更新媒体库才能看到最新的视频的缩略图[java]
- 场景:当我们正在master分支开发新功能的时候,突然接到一个任务发现线上出现了一个紧急的BUG需要修复,由于没有打新分支做这部分新需求,这
- 本文实例为大家分享了Android DialogUtils弹出窗工具类的具体代码,供大家参考,具体内容如下直接上代码吧!!!代码拉过去都可以
- 解锁、唤醒屏幕用到KeyguardManager,KeyguardLock,PowerManager,PowerManager.WakeLo
- static目的java中的static关键字主要用于内存管理。static范围使用范围:java static关键字可以用在变量、方法、代
- springboot连接sqllite的坑2021-01-04 13:54:14.178 SvUSService [main] ERROR
- Android Java 如何调用自己的 C++ 的类库下面以 Java 调用 C++ 的加法运算函数为例,做简单说明。(使用 Androi
- 因为线程重用导致的信息错乱的bugThreadLocal一般用于线程间的数据隔离,通过将数据缓存在ThreadLocal中,可以极大的提升性
- 我们先来看完整的代码:import java.io.File;public class JudgeFile {public static v