how2j.cn

下载区
文件名 文件大小
请先登录 19m
增值内容 19m
19m
使用站长秘制下载工具

6分51秒
本视频采用html5方式播放,如无法正常播放,请将浏览器升级至最新版本,推荐火狐,chrome,360浏览器。 如果装有迅雷,播放视频呈现直接下载状态,请调整 迅雷系统设置-基本设置-启动-监视全部浏览器 (去掉这个选项)。 chrome 的 视频下载插件会影响播放,如 IDM 等,请关闭或者切换其他浏览器

步骤 1 : PropertyService   
步骤 2 : BaseService   
步骤 3 : BaseServiceImpl   
步骤 4 : List listByParent(Object parent);   
步骤 5 : list(Page page, Object parent);   
步骤 6 : int total(Object parentObject);   
步骤 7 : PropertyService   
步骤 8 : PropertyServiceImpl   
步骤 9 : PropertyAction   
步骤 10 : 可运行项目   

增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
package com.how2java.tmall.service; import java.util.List; import com.how2java.tmall.pojo.Category; import com.how2java.tmall.util.Page; public interface PropertyService extends BaseService{ public List listByCategory(Category category); public List list(Page page,Category category); public int total (Category category); }
package com.how2java.tmall.service;
 
import java.util.List;
 
import com.how2java.tmall.pojo.Category;
import com.how2java.tmall.util.Page;
 
public interface PropertyService extends BaseService{
    public List listByCategory(Category category);
    public List list(Page page,Category category);
    public int total (Category category);
}
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
package com.how2java.tmall.service; import java.util.List; import com.how2java.tmall.util.Page; public interface BaseService { public Integer save(Object object); public void update(Object object); public void delete(Object object); public Object get(Class clazz,int id); public Object get(int id); public List list(); public List listByPage(Page page); public int total(); public List listByParent(Object parent); public List list(Page page, Object parent); public int total(Object parentObject); }
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
package com.how2java.tmall.service.impl; import java.util.HashMap; import java.util.List; import java.util.Set; import org.apache.commons.lang3.StringUtils; import org.hibernate.criterion.DetachedCriteria; import org.hibernate.criterion.Order; import org.hibernate.criterion.Restrictions; import org.springframework.stereotype.Service; import com.how2java.tmall.service.BaseService; import com.how2java.tmall.util.Page; @Service public class BaseServiceImpl extends ServiceDelegateDAO implements BaseService { protected Class clazz; public BaseServiceImpl(){ try{ throw new Exception(); } catch(Exception e){ StackTraceElement stes[]= e.getStackTrace(); String serviceImpleClassName= stes[1].getClassName(); try { Class serviceImplClazz= Class.forName(serviceImpleClassName); String serviceImpleClassSimpleName = serviceImplClazz.getSimpleName(); String pojoSimpleName = serviceImpleClassSimpleName.replaceAll("ServiceImpl", ""); String pojoPackageName = serviceImplClazz.getPackage().getName().replaceAll(".service.impl", ".pojo"); String pojoFullName = pojoPackageName +"."+ pojoSimpleName; clazz=Class.forName(pojoFullName); } catch (ClassNotFoundException e1) { e1.printStackTrace(); } } } @Override public List list() { DetachedCriteria dc = DetachedCriteria.forClass(clazz); dc.addOrder(Order.desc("id")); return findByCriteria(dc); } @Override public int total() { String hql = "select count(*) from " + clazz.getName() ; List<Long> l= find(hql); if(l.isEmpty()) return 0; Long result= l.get(0); return result.intValue(); } @Override public List<Object> listByPage(Page page) { DetachedCriteria dc = DetachedCriteria.forClass(clazz); dc.addOrder(Order.desc("id")); return findByCriteria(dc,page.getStart(),page.getCount()); } @Override public Integer save(Object object) { return (Integer) super.save(object); } @Override public Object get(Class clazz, int id) { return super.get(clazz, id); } @Override public Object get(int id) { return get(clazz, id); } @Override public List listByParent(Object parent) { String parentName= parent.getClass().getSimpleName(); String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName); DetachedCriteria dc = DetachedCriteria.forClass(clazz); dc.add(Restrictions.eq(parentNameWithFirstLetterLower, parent)); dc.addOrder(Order.desc("id")); return findByCriteria(dc); } @Override public List list(Page page, Object parent) { String parentName= parent.getClass().getSimpleName(); String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName); DetachedCriteria dc = DetachedCriteria.forClass(clazz); dc.add(Restrictions.eq(parentNameWithFirstLetterLower, parent)); dc.addOrder(Order.desc("id")); return findByCriteria(dc,page.getStart(),page.getCount()); } @Override public int total(Object parentObject) { String parentName= parentObject.getClass().getSimpleName(); String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName); String sqlFormat = "select count(*) from %s bean where bean.%s = ?"; String hql = String.format(sqlFormat, clazz.getName(), parentNameWithFirstLetterLower); List<Long> l= this.find(hql,parentObject); if(l.isEmpty()) return 0; Long result= l.get(0); return result.intValue(); } }
步骤 4 :

List listByParent(Object parent);

edit
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
public List listByParent(Object parent) { String parentName= parent.getClass().getSimpleName(); String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName); DetachedCriteria dc = DetachedCriteria.forClass(clazz); dc.add(Restrictions.eq(parentNameWithFirstLetterLower, parent)); dc.addOrder(Order.desc("id")); return findByCriteria(dc); }
	public List listByParent(Object parent) {
		String parentName= parent.getClass().getSimpleName();
		String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName);
		DetachedCriteria dc = DetachedCriteria.forClass(clazz);
		dc.add(Restrictions.eq(parentNameWithFirstLetterLower, parent));
		dc.addOrder(Order.desc("id"));
		return findByCriteria(dc);
	}
步骤 5 :

list(Page page, Object parent);

edit
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
public List list(Page page, Object parent) { String parentName= parent.getClass().getSimpleName(); String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName); DetachedCriteria dc = DetachedCriteria.forClass(clazz); dc.add(Restrictions.eq(parentNameWithFirstLetterLower, parent)); dc.addOrder(Order.desc("id")); return findByCriteria(dc,page.getStart(),page.getCount()); }
	public List list(Page page, Object parent) {
		String parentName= parent.getClass().getSimpleName();
		String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName);
		DetachedCriteria dc = DetachedCriteria.forClass(clazz);
		dc.add(Restrictions.eq(parentNameWithFirstLetterLower, parent));
		dc.addOrder(Order.desc("id"));
		return findByCriteria(dc,page.getStart(),page.getCount());
	}
步骤 6 :

int total(Object parentObject);

edit
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
public int total(Object parentObject) { String parentName= parentObject.getClass().getSimpleName(); String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName); String sqlFormat = "select count(*) from %s bean where bean.%s = ?"; String hql = String.format(sqlFormat, clazz.getName(), parentNameWithFirstLetterLower); List<Long> l= this.find(hql,parentObject); if(l.isEmpty()) return 0; Long result= l.get(0); return result.intValue(); }
	public int total(Object parentObject) {
		String parentName= parentObject.getClass().getSimpleName();
		String parentNameWithFirstLetterLower = StringUtils.uncapitalize(parentName);
		
		String sqlFormat = "select count(*) from %s bean where bean.%s = ?";
		String hql = String.format(sqlFormat, clazz.getName(), parentNameWithFirstLetterLower);
		
		List<Long> l= this.find(hql,parentObject);
		if(l.isEmpty())
			return 0;
		Long result= l.get(0);
		return result.intValue();
	}
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
步骤 8 :

PropertyServiceImpl

edit
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
package com.how2java.tmall.service.impl; import org.springframework.stereotype.Service; import com.how2java.tmall.service.PropertyService; @Service public class PropertyServiceImpl extends BaseServiceImpl implements PropertyService { }
package com.how2java.tmall.service.impl;

import org.springframework.stereotype.Service;

import com.how2java.tmall.service.PropertyService;

@Service
public class PropertyServiceImpl extends BaseServiceImpl implements PropertyService {

}
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
增值内容,请先登录
完整的SSH模仿天猫项目,使用J2SE、前端技术(包含所有前端jsp文件)、J2EE,SSH一整套技术栈, 从无到有涵盖全部133个知识点,571个开发步骤, 充实SSH项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢


HOW2J公众号,关注后实时获知最新的教程和优惠活动,谢谢。


问答区域    
2018-06-13 请问dc.add(Restrictions.eq(parentNameWithFirstLetterLower, parent)); 这个是什么意思呢?
牛肉面面

我知道是加入一个限制条件 ,如果是 Restrictions.eq(“name”, "123")可以理解成 查找name=123的记录,但是 Restrictions.eq(parentNameWithFirstLetterLower, parent)这个该怎么理解呢?




1 个答案

how2j
答案时间:2018-06-13
这个是根据父类查找,比如查找指定分类下的所有产品,就要用到这个



回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到




2018-03-04 关于hql添加父类限制的问题?
菠萝蜜

"select count(*) from %s bean where bean.%s = ?"; 上面的where条件就是指定当前类的父类。不明白这个是如何工作的,在数据库中,当前类都没有父类字段的啊。希望站长帮忙解答下,谢谢。




1 个答案

how2j
答案时间:2018-03-05
有的吧,比如product表,不就有cid字段吗,怎么会没有呢~



回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到




2017-10-21 步骤6关于hql用类名操作对应数据库表数据的问题




提问之前请登陆
提问已经提交成功,正在审核。 请于 我的提问 处查看提问记录,谢谢
关于 实践项目-天猫整站SSH-Service重构-关系 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 635924385
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
在已经存在的几千个提问里,有相当大的比例,是因为使用了和站长不同版本的开发环境导致的,比如 jdk, eclpise, idea, mysql,tomcat 等等软件的版本不一致。
请使用和站长一样的版本,可以节约自己大量的学习时间。 站长把教学中用的软件版本整理了,都统一放在了这里, 方便大家下载: https://how2j.cn/k/helloworld/helloworld-version/1718.html

上传截图