java中的命令怎么上移_web系统中上下移动功能的实现

其实上移下移的思想分几步:

核心思想:交换两个记录的位置字段的值。

问题:如何根据当前记录,找到前一个或者后一个的记录的位置。

第一:在java类属性定义一个position位置字段,不同的位置position的值不同。

第二:前台页面显示移动的效果是查询的时候,根据position的升序查询显示出来的。所以要重写查询方法。

第三:当点击按钮的时候,可以获取该记录的id,根据id获取该记录的对象的position。然后通过查询语句获取前一个或者后一个记录

第四:如何保证在添加新的信息的时候,position的值不会重复。这里很巧妙:根据id的值来设置position的值。

c1a3ceaa56fade9ccfc01d983c4a6c42.png

package cn.itcast.oa.service.impl;

import java.util.List;

import javax.annotation.Resource;

import org.hibernate.SessionFactory;

import org.springframework.stereotype.Service;

import org.springframework.transaction.annotation.Transactional;

import cn.itcast.oa.base.DaoSupportImpl;

import cn.itcast.oa.domain.ForumManage;

import cn.itcast.oa.service.ForumManageService;

@Service

@Transactional

public class ForumManageServiceImpl extends DaoSupportImpl implements ForumManageService {

/*实现上下移动的操作,页面如何更新已经改过的信息呢,因为之前的findAll查询没有条件的,没有排序的,而我们这个列表是根据postion来进行排序展示的

子类继承父类的方法,可以重写父类的方法以实现自己的功能.子类重写了父类,就执行自己的方法了。

*/

@Override

public List findAll() {

return getSession().createQuery("FROM ForumManage ORDER BY position ").list();

}

//当添加一个新的记录时,position的值是不能重复的,这里的方法很巧妙,根据id来保存position的值,id为什么,position就是什么,这样子就不会重复了

@Override

public void save(ForumManage forum) {

super.save(forum);

//先保存了对象后,根据id来保存position的值,这样就不会重复了

forum.setPosition(forum.getId().intValue());

}

@Override

public void moveUp(Long id) {

/*jsp页面上的上移下移功能实现:

* 分析:上下移动每条记录是针对记录的位置进行的移动,所以这里我们在java类中的字段中设置一个position位置来记录每条记录的位置信息。

* 而想要交换两条记录,只要将这两条记录的位置信息交换,然后利用查询的时候order by来进行查询,就可以将两条记录来交换。

* 第一步:之前我们写的查询方法是无条件查询,这里的查询是有条件的查询,所以需要重写父的findAll方法,否则数据库改了,页面是不会改变的。

* (关于子类继承父类,这个可以联想生活中的父子关系,子类继承了父类的某个特点,将这个特点修改了下成了自己特有的,所以重写是先使用自己的特点)

* 第二步:当我们点击上下移动按钮时,这时候页面传递是改记录的id信息,根据id信息来获取当前的对象。

* 第三步:如何获取当前记录之前的或者之后的记录呢。这是问题的关键:即如何获取前一个或者后一个对象。

* 第四步:将第一步和第二步的对象position信息进行交换,然后更新到数据库。

* 子类继承父类,调用父类的方法:直接拿过来用即可,即在子类中直接写父类的方法就可以。比如我们要使用爸爸的东西,我们不用汇报,而使用别人的东西需要汇报说一声。这个汇报就是先声明一个对象

* */

//当前对象和前面一个或者后面一个对象的获取,当前对象通过id获取,后面一个对象通过查询语句获取

ForumManage forum= getById(id);

ForumManage other=null;

//这是查询上下对象的方法:select * from itcast_forumManage where position

other=(ForumManage) getSession().createQuery(//

"FROM ForumManage WHERE position < ? ORDER BY position DESC ")

.setParameter(0,forum.getPosition())

.setFirstResult(0)

.setMaxResults(1)

.uniqueResult();

//最上面的一个不能上移

if (other==null) {

return;

}

//获取到了前面一个对象后,得到该对象的位置,将两者的位置进行交换,注意这里需要用到第三方来转接

Integer temp=null;

temp=forum.getPosition();

forum.setPosition(other.getPosition());

other.setPosition(temp);

//交换之后,更新到数据库,

getSession().update(forum);

getSession().update(other);

}

//下移跟上移的原理是一样的

@Override

public void moveDown(Long id) {

//当前对象和前面一个或者后面一个对象的获取,当前对象通过id获取,后面一个对象通过查询语句获取

ForumManage forum= getById(id);

ForumManage other=null;

//这是查询上下对象的方法:select * from itcast_forumManage where position

other=(ForumManage) getSession().createQuery(//

"FROM ForumManage WHERE position > ? ORDER BY position ")

.setParameter(0,forum.getPosition())

.setFirstResult(0)

.setMaxResults(1)

.uniqueResult();

//最下面的一个不能下移

if (other==null) {

return;

}

//获取到了前面一个对象后,得到该对象的位置,将两者的位置进行交换,注意这里需要用到第三方来转接

Integer temp=null;

temp=forum.getPosition();

forum.setPosition(other.getPosition());

other.setPosition(temp);

//交换之后,更新到数据库,

getSession().update(forum);

getSession().update(other);

}

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值