spring @Repository 和@Service,@Controller使用方法

spring @Repository 和@Service,@Controller使用方法

Web 应用程序采用了经典的三层分层结构的话,最好在持久层、业务层和控制层分别采用 @Repository、@Service 和 @Controller 对分层中的类进行注释;

实际使用中

实例一:@Repository

spring @Repository 和@Service,@Controller使用方法

上图中的application3.xml是配置文件,test2是测试类。其他的不用管;

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:="http://www.springframework.org/schema/beans"
	   xmlns:context="http://www.springframework.org/schema/context"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
       xsi:schemaLocation="http://www.springframework.org/schema/beans  
           				   http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
                           http://www.springframework.org/schema/context
                           http://www.springframework.org/schema/context/spring-context-2.5.xsd">
            
		 <context:component-scan base-package="com.introduce.Dao"></context:component-scan>
</beans>

配置文件是启动spring容器时扫描com.introduce.Dao所有的注解。


test2测试类

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.introduce.Dao.UserDao;

public class Test2 {
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext3.xml");
		UserDao userDao=ac.getBean(UserDao.class);
		userDao.getUser2("haha");
	}
}

UserDao接口和它的实现类UserDaoImpl

package com.introduce.Dao;


import com.introduce.Model.User2;
public interface UserDao{
	User2 getUser2();

	User2 getUser2(String name);

}
package com.introduce.Dao;

import org.apache.ibatis.session.SqlSession;


import org.apache.ibatis.session.SqlSessionFactory;

import org.springframework.stereotype.Repository;
import org.springframework.stereotype.Service;
import com.introduce.Model.User2;
@Service
public class UserDaoImpl implements UserDao{
//	private SqlSessionFactory sqlSessionFactory; 
//	public UserDaoImpl(SqlSessionFactory sqlSessionFactory){
//		this.sqlSessionFactory=sqlSessionFactory;
//	}
	@Override
	public User2 getUser2() {
		
		return null;
	}

	@Override
	public User2 getUser2(String name) {
		// TODO Auto-generated method stub
//		SqlSession sqlSession=sqlSessionFactory.openSession();
//		User2 user2=sqlSession.selectOne("com.introduce.Modle.User2.getUser2",name);
		User2 user2=new User2();
		user2.setAge(22);
		System.out.println(name);
		return  user2;
	}
}


这样在启动后就会打印出user实现类方法的内容。

注:至于注解中@Service()的括号中要不要加字符串,如@Service(“userDao”).这里是加不加,加什么样的字符都无所谓,因为只有一个实现类,当有多个实现类是,也可以不用填,在下面的实例二中,会通过@Qualifier()来指定特定的实现了。如果填了,要保证两个字符串不相等即可。一般项目中安全起见会以实现类名为准,避免重复。

实例二:@Repository 与service一起使用,并当有多个实现类时,如何指定某个实现类。

测试类 main方法:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.introduce.Dao.UserDao;
import com.introduce.Dao.UserServiceImpl;
import com.introduce.Dao.UserService;

public class Test2 {
	
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		ApplicationContext ac=new ClassPathXmlApplicationContext("applicationContext3.xml");
		UserService userService=ac.getBean(UserService.class);
		userService.ff();
//		UserDao userDao=ac.getBean(UserDao.class);
//		userDao.getUser2("haha");
		
	}
}

main方法中找到容器中的userService.class类。

进入到service接口和实现类

package com.introduce.Dao;

public interface UserService {
void ff();
}
package com.introduce.Dao;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Service;

import com.introduce.Dao.UserDao;
@Service
public class UserServiceImpl implements UserService1{
	@Autowired
	@Qualifier("userDaoImpl2")
	UserDao userDao;
	
	public void ff(){
		userDao.getUser2("oo");
	}

}

在service的实现类中有两点,一是加@Service;二是使用@Qualifier()指定某个实现类。@Qualifier()括号中的字符串某人是实现类的类名首字母小写,当然也可以自己定义,如在实现类的其中一个service(“s1”),另一个service(“s2”);即可。下面的代码是没加的。可以手动加,然后再@Qualifier(‘s2’)就会执行userDaoImpl类的方法。


dao层的三个类,一个接口,两个实现类

package com.introduce.Dao;


import com.introduce.Model.User2;
public interface UserDao{
	User2 getUser2();

	User2 getUser2(String name);

}

package com.introduce.Dao;

import org.apache.ibatis.session.SqlSession;


import org.apache.ibatis.session.SqlSessionFactory;

import org.springframework.stereotype.Repository;
import org.springframework.stereotype.Service;
import com.introduce.Model.User2;
@Service
public class UserDaoImpl implements UserDao{
//	private SqlSessionFactory sqlSessionFactory; 
//	public UserDaoImpl(SqlSessionFactory sqlSessionFactory){
//		this.sqlSessionFactory=sqlSessionFactory;
//	}
	@Override
	public User2 getUser2() {
		
		return null;
	}

	@Override
	public User2 getUser2(String name) {
		// TODO Auto-generated method stub
//		SqlSession sqlSession=sqlSessionFactory.openSession();
//		User2 user2=sqlSession.selectOne("com.introduce.Modle.User2.getUser2",name);
		User2 user2=new User2();
		user2.setAge(22);
		System.out.println(name);
		return  user2;
	}
}

package com.introduce.Dao;

import org.springframework.stereotype.Service;

import com.introduce.Model.User2;
@Service
public class UserDaoImpl2 implements UserDao{
	@Override
	public User2 getUser2() {
		
		return null;
	}

	@Override
	public User2 getUser2(String name) {
		// TODO Auto-generated method stub
//		SqlSession sqlSession=sqlSessionFactory.openSession();
//		User2 user2=sqlSession.selectOne("com.introduce.Modle.User2.getUser2",name);
		User2 user2=new User2();
		user2.setAge(22);
		System.out.println(name);
		return  user2;
	}
}


细心的朋友可以看到我的userDaoImpl和userDaoImpl2两个实现类都是使用的@Service。可是程序也能正常执行。如果把@Service换成@Repository程序

也是可以正常执行的。所以二者并没有功能上的差别,只是为了配合spingmvc 三层架构区分开的别名。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106266.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • PyCharm激活码永久有效PyCharm2017.3.6激活码教程-持续更新,一步到位

    PyCharm激活码永久有效PyCharm2017.3.6激活码教程-持续更新,一步到位PyCharm激活码永久有效2017.3.6激活码教程-Windows版永久激活-持续更新,Idea激活码2017.3.6成功激活

    2022年6月19日
    29
  • log4j conversionpattern详解_log4j配置文件

    log4j conversionpattern详解_log4j配置文件#locallog4j.rootCategory=ERROR,stdout,report-error#online#log4j.rootCategory=ERROR,report-error#Consolelog4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdou…

    2022年8月22日
    6
  • 最新仿金蝶电商ERP进销存系统软件源码 销售库存仓库财务管理收银系统网络版「建议收藏」

    最新仿金蝶电商ERP进销存系统软件源码 销售库存仓库财务管理收银系统网络版「建议收藏」源码说明:超强的工作流系统,强大的可视化工作流编辑器,灵活自定义表单设计,充分实现企业基于工作流的各项业务管理,与其他模块数据(如HRM等)完美结合。全面综合的任务系统,实现基于信息录入、单据管理、业务协作、工作流转、任务提醒、统计分析等的智能管理。所有单据均支持上传附件功能;且报价单、销售合同、采购订单、发货出库、入库单、派工单等所有模板均支持自定义编辑打印。集成功能实用的CRM系统、进销存系统、生产ERP系统,实现对客户销售、供应商采购、产品物料、库存统计、生产监控等的精细化管理,直观强大的销售

    2022年5月11日
    48
  • jvm的垃圾回收算法_jvm垃圾回收策略

    jvm的垃圾回收算法_jvm垃圾回收策略前言相比C语言,JVM虚拟机一个优势体现在对对象的垃圾回收上,JVM有一套完整的垃圾回收算法,可以对程序运行时产生的垃圾对象进行及时的回收,以便释放JVM相应区域的内存空间,确保程序稳定高效的运行,但在真正了解垃圾回收算法之前,有必要对JVM的对象的引用做一个简单的铺垫JVM对象可达性分析算法Java虚拟机中的垃圾回收器采用可达性分析来探索所有存活的对象扫描堆中的对象,看是否能够沿着GCRoot对象为起点的引用链找到该对象,找不到表示可以被回收想象一下,对象在什么情况下会被认为是垃圾对象呢?

    2025年10月26日
    2
  • Windows安装配置ffmpeg

    Windows安装配置ffmpegwindows 下下载配置 ffmpeg

    2025年8月22日
    3
  • android之java程序性能优化(不断补充)

    在JAVA程序中,性能问题的大部分原因并不在于JAVA语言,而是程序本身。养成良好的编码习惯非常重要,能够显著地提升程序性能。一、避免在循环条件中使用复杂表达式在不做编译优化的情况下,在循环中,循环条件会被反复计算,如果不使用复杂表达式,而使循环条件值不变的话,程序将会运行的更快。还有一个原则,决不在一个For语句中第二次调用一个类的方法例子: class cel

    2022年3月9日
    57

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号