当前位置: 首页 > 知识库问答 >
问题:

考虑在配置中定义一个类型为“com.gisapp.gisapp.dao.IUserDAO”的bean

陆宇航
2023-03-14

当我启动我的spring-boot应用程序时,我有这样的消息:

com.gisapp.services.impl.userservice中的字段userDAO需要类型为“com.gisapp.gisapp.dao.IUserdao”的bean,但找不到该bean。

注入点有以下注释:-@org.springframework.beans.factory.annotation.AutoWired(required=true)

行动:

考虑在配置中定义一个类型为“com.gisapp.gisapp.dao.IUserDAO”的bean。

我在其他与此问题相关的帖子中读到的内容是,我必须配置注释@ComponentScan,但它不起作用

package com.gisapp.gisapp;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ComponentScan;

@SpringBootApplication
@ComponentScan("com.gisapp")
public class GisappApplication {

    public static void main(String[] args) {
        SpringApplication.run(GisappApplication.class, args);
    }

}
@Service
public class UserService implements IUserService {

    @Autowired
    IUserDAO userDAO;

    @Override
    @Transactional(readOnly=true)
    public  Object login() {


        return userDAO.login();
    }

}
package com.gisapp.gisapp.dao.impl;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.Query;

import com.gisapp.gisapp.dao.IUserDAO;
import com.gisapp.models.entity.User;

public class UserDAO implements IUserDAO{

    @Override
    public Object login() {

        StringBuilder query = new StringBuilder();

        query.append("SELECT * FROM User");

        EntityManager em = null;
        Query q = em.createNativeQuery(query.toString());

        List<User> result=q.getResultList();

        return result;

    }

}

共有1个答案

施飞鸿
2023-03-14

1)添加@repository注释,以便将DAO作为bean加载到spring上下文中:

@Repository
public class UserDAO implements IUserDAO{

2)只是在旁边..您很可能还应该在其中注入EntityManager:

@PersistenceContext
private EntityManager em;
 类似资料: