发现一个比较有意思的bug,
//Action中以get开头且返回类型不为void(如 public Object get*() )的方法会被自动执行
//放入值栈时会执行一次,
//若在页面调用则再执行一次
如下面这个method
public String getUserByID() { System.out.println("userAction.getUserByID()执行中。。。"); idUser = userService.getUserByID(user.getUid()); return SUCCESS; }
若调用调用这个方法会发现,查询语句被执行了两次
UserAction.getUser()执行中。。。 userAction.getUserByID()执行中。。。 Hibernate: select user0_.uid as uid1_0_0_, user0_.username as username2_0_0_, user0_.address as address3_0_0_ from tbl_user user0_ where user0_.uid=? userAction.getIdUser()执行中。。。 userAction.getIdUser()执行中。。。 userAction.getIdUser()执行中。。。 userAction.getIdUser()执行中。。。 userAction.getUserList()执行中。。。 userAction.getPageList()执行中。。。 userAction.getIdUser()执行中。。。 userAction.getName()执行中。。。 UserAction.getPage()执行中。。。 userAction.getPageList()执行中。。。 UserAction.getUser()执行中。。。 userAction.getUserByID()执行中。。。 Hibernate: select user0_.uid as uid1_0_0_, user0_.username as username2_0_0_, user0_.address as address3_0_0_ from tbl_user user0_ where user0_.uid=? userAction.getUserList()执行中。。。
而且在执行其他method方法时也会调用这个方法,这样会导致程序跳出异常,把method名改为selectUserByID()问题解决
原文地址:https://www.cnblogs.com/annofyf/p/9797827.html
时间: 2024-10-10 08:35:45