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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Django之ORM模型建议收藏

    ORM介绍对象关系映射(ObjectRelationalMapping,简称ORM)模式的作用是在关系型数据库与业务实体对象之间进行映射,这使得我们不需要再去和复杂的SQL语句打交道,只需要简单

    2021年12月19日
    39
  • 字典树的数据结构_数据结构快速排序

    字典树的数据结构_数据结构快速排序本文主要包括以下内容:Trie字典树的基本概念Trie字典树的基本操作插入查找前缀查询删除基于链表的Trie字典树Set性能对比LeetCode相关线段树的问题LeetCode第208号问题LeetCode第211号问题LeetCode第677号问题Trie字典树的基本概念上一篇我们介绍了线段树(SegmentTree),本文主要介绍Trie字典树…

    2022年9月6日
    0
  • 新手上路之oracle 视图 索引(了解)笔记

    新手上路之oracle 视图 索引(了解)笔记一.视图视图:建立在表|结果集|视图上的虚拟表,有以下作用1、简化:select查询语句2、重用:封装select语句命名3、隐藏:内部细节4、区分:相同数据不同查询不是所有的用户都有创建视图的权限1、前提:createview–>组connectresourcedba2、授权:–>sqlplus/nologa)、sys登录connsys

    2022年7月22日
    5
  • BP神经网络算法基本原理_卷积神经网络推导过程

    BP神经网络算法基本原理_卷积神经网络推导过程原文写于2018年5月。修改于2019年11月17。最近在学习《DeepLearning》这本书,书中在前馈神经网络、全连接神经网络以及卷积神经网络等内容中,都有提到反向传播算法,这一算法可以说是神经网络中求解参数比较核心的部分了。为了更好地理解神经网络工作的原理,认识反向传播在神经网络中的运算机制,在综合《DeepLearning》书中的有关部分并且学习了b站讲解神经网络的相关视频及一…

    2022年9月12日
    0
  • 【日用】获取pfx证书序列号[通俗易懂]

    【日用】获取pfx证书序列号[通俗易懂]一、使用java代码packagecom.sanglp.util;importjava.io.ByteArrayInputStream;importjava.io.File;importjava.io.IOException;importjava.math.BigInteger;importjava.security.KeyStore;importjava.security.cert.X509Certificate;importjava.util.Enumeration;

    2022年5月2日
    62
  • idea19.3.4激活码【2021.7最新】

    (idea19.3.4激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlMLZPB5EL5Q-eyJsaWN…

    2022年3月20日
    120

发表回复

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

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