java - CRUDRepository findAll 发现空

标签 java mysql hibernate spring-boot

我似乎无法让 hibernate 从 mySQL 获取任何信息。我到处都读过,我觉得我这样做是正确的,显然我不是,但我的大脑在试图理解我搞砸的事情时崩溃了。

主要:

@SpringBootApplication
@ComponentScan("com.luv2code")
@EntityScan("com.luv2code.entity")
@EnableJpaRepositories("com.luv2code.dao")
public class App {
    public static void main(String[] args) {
        SpringApplication.run(App.class, args);
    }
}

Controller :

@Controller
public class CustomerController {


    private CustomerDAO customerDAO;

    @Autowired
    public void setCustomerDAO(CustomerDAO customerDAO) {
        this.customerDAO = customerDAO;
    }

    @RequestMapping("/")
    public String listCustomers(Model model){

        long test = customerDAO.count();
        model.addAttribute("answer", test);

        List<Customer> customers = customerDAO.findAll();
        model.addAttribute("customers", customers);
        return "home";
    }

}

应用程序属性:

spring.datasource.url = jdbc:mysql://localhost:3306/web_customer_tracker?useSSL=false
spring.datasource.username=root
spring.datasource.password=metalgear3
spring.datasouce.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.hibernate.ddl-auto=update
spring.jpa.hibernate.show-sql=true
spring.jpa.hibernate.dialect=org.hibernate.dialect.MySQL55Dialect

spring.jpa.properties.hibernate.current_session_context_class=org.springframework.orm.hibernate5.SpringSessionContext
entitymanager.packagesToScan = com.luv2code.entity.Customer

实体:

@Entity
@Table(name = "customer")
public class Customer implements Serializable {

    @Column(name = "id")
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Id
    private int id;

    @Column(name = "first_name")
    private String firstName;

    @Column(name = "last_name")
    private String lastName;

    @Column(name = "email")
    private String email;

    public Customer(){}

    @Override
    public String toString() {
        return "Customer{" +
                "id=" + id +
                ", firstName='" + firstName + '\'' +
                ", lastName='" + lastName + '\'' +
                ", email='" + email + '\'' +
                '}';
    }

    public Customer(String firstName, String lastName, String email){
        this.firstName = firstName;
        this.lastName = lastName;
        this.email = email;

    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getFirstName() {
        return firstName;
    }

    public void setFirstName(String firstName) {
        this.firstName = firstName;
    }

    public String getLastName() {
        return lastName;
    }

    public void setLastName(String lastName) {
        this.lastName = lastName;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}

DAO:

@Repository("CustomerDAO")
@Transactional
public interface CustomerDAO extends CrudRepository<Customer, Integer> {

    public List<Customer> findAll();
    public long count();
}

MySql:

CREATE DATABASE IF NOT EXISTS `web_customer_tracker`;
USE `web_customer_tracker`;

DROP TABLE IF EXISTS `customer`;
CREATE TABLE `customer`(
`id` INT(11) NOT NULL auto_increment,
`first_name` VARCHAR(45) DEFAULT NULL,
`last_name` VARCHAR(45)DEFAULT NULL,
`email` VARCHAR(45) DEFAULT NULL,
PRIMARY KEY(`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 CHARSET=latin1;


INSERT INTO `customer` VALUES
    (1, 'David', 'Adams', 'david@luv2code.com'),
    (2, 'John', 'Die', 'john@luv2code.com'),
    (3, 'Ajay', 'Rao', 'ajay@luv2code.com'),
    (4, 'Mary', 'Publiidc', 'mary@luv2code.com'),
    (5, 'Maxwell', 'Dixon', 'maxwell@luv2code.com');

最佳答案

我知道现在回复有点晚了,但这个问题对 Google 来说是友好的。

您不需要在 CustomerDAO 中声明 findAll()。接口(interface) CrudRepository 已经做到了这一点。最重要的是,我建议改为实现 JpaRepository 存储库(它扩展了 CrudRepository 本身,并免费为您提供更多便捷的方法。

关于java - CRUDRepository findAll 发现空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43564402/

相关文章:

java: JOptionPane.showInputDialog 空指针异常

java - 如何检查平板电脑是否插入了SD卡 : Android?

Java 程序运行良好但无法编译

mysql - 删除除具有最大日期的行之外的所有行

java - 动态切换数据源

java - 字符串条件检查测试失败

mysql - SQL 查询 - 从多个表中获取计数

mysql - 如何防止大型MySQL导入的连接超时

java - Hibernate 一对一单向 - id 未分配

Java/hibernate : how to write DAO code for complex SQLs