java web dao_JavaWeb项目,DAO应该怎么写?

Hibernate的QBC一定能满足你的需要~

这里给你个例子:

//B2C商城中根据商品标题模糊查询商品

public List findByTitle(String title, int pageIndex, int orderType) {

try {

Criteria criteria = this.currentSession().createCriteria(Goods.class);

// 是否只显示已发布商品

if (this.onlyShowEnabled) {

criteria.add(Restrictions.eq("enabled", true));

}

// 根据商品标题模糊查询

criteria.add(Restrictions.like("title", "%" + title + "%"));

// 选择排序方式

criteria = this.order(criteria, orderType);

// 分页处理

List list = super.page(criteria, pageIndex);

return list;

} catch(Exception e) {

System.out.println("GoodsDao >> findByTitle >> " + e);

return null;

}

}

//不同的排序方式

private Criteria order(Criteria criteria, int orderType) throws Exception {

if (orderType == IGoodsDao.ORDER_TYPE_LATEST) {

return criteria.addOrder(org.hibernate.criterion.Order.desc("publishDate"));

} else if (orderType == IGoodsDao.ORDER_TYPE_PRICE_HIGHEST) {

return criteria.addOrder(org.hibernate.criterion.Order.desc("maxPrice"));

} else if (orderType == IGoodsDao.ORDER_TYPE_PRICE_LOWEST) {

return criteria.addOrder(org.hibernate.criterion.Order.asc("minPrice"));

} else if (orderType == IGoodsDao.ORDER_TYPE_HOTTEST) {

return criteria.addOrder(org.hibernate.criterion.Order.desc("purchaseOrderNum"));

} else {

throw new Exception("不支持该排序类型");

}

}

至于super.page()方法是继承了一个BaseDao类,以下是实现:

/**

* QBC形式分页查询

* @param criteria 查询条件对象

* @param pageIndex 页码

* @param pageSize 页面大小

* @return 分页查询的结果

* @throws HibernateException

*/

protected List page(Criteria criteria, int pageIndex, int pageSize) throws HibernateException {

@SuppressWarnings("unchecked")

List list = criteria.setFirstResult(pageSize * pageIndex)

.setMaxResults(pageSize).list();

return list;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java EE 项目的目录结构可以根据具体的需求进行灵活设计,但一般情况下,推荐使用以下的标准目录结构: ``` project ├── src │ ├── main │ │ ├── java │ │ │ └── com │ │ │ └── example │ │ │ ├── controller │ │ │ ├── dao │ │ │ ├── entity │ │ │ ├── service │ │ │ └── util │ │ ├── resources │ │ │ ├── mapper │ │ │ └── db.properties │ │ └── webapp │ │ ├── WEB-INF │ │ │ ├── classes │ │ │ ├── lib │ │ │ └── web.xml │ │ ├── css │ │ ├── js │ │ ├── images │ │ └── index.jsp │ └── test │ ├── java │ └── resources ├── target ├── pom.xml └── README.md ``` 其中,各个目录的作用如下: - `src/main/java`:存放项目Java 源代码,按照包名分层,一般包括 `controller`、`dao`、`entity`、`service` 和 `util` 等包; - `src/main/resources`:存放项目的配置文件和资源文件,一般包括数据库连接配置文件 `db.properties`、MyBatis 的 mapper 文件等; - `src/main/webapp`:存放 Web 应用的 Web 资源,包括 JSP 页面、CSS 样式表、JavaScript 脚本等; - `src/test/java`:存放项目的测试代码; - `src/test/resources`:存放测试代码所需要的资源文件; - `target`:存放编译后的 .class 文件、打包后的 .war 文件等; - `pom.xml`:Maven 项目管理工具的配置文件; - `README.md`:项目说明文件。 以上是一种常见的 Java EE 项目目录结构,但并不是唯一的标准。在实际开发中,可以根据项目的具体需求进行合理的调整和修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值