springboot2.0 集合JPA

pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>com.JPA</groupId>
	<artifactId>jpa</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>jpa</name>
	<description>Demo project for Spring Boot</description>

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.0.2.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
		<java.version>1.8</java.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-data-jpa</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-thymeleaf</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-devtools</artifactId>
			<scope>runtime</scope>
		</dependency>
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<scope>runtime</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>


</project>

application.properties

#datasource tomcat - jdbc
spring.datasource.url=jdbc:mysql://localhost:3306/springboot?useUnicode=true&characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=root

#JPA
# 如果有的话,只会更新表结构而不会建立
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true

实体类:

package com.jpa.bean;

import javax.persistence.*;

/**
 * Created by  lpw'ASUS on 2018/5/30.
 */

@Entity
public class UserInfo {

    private Integer id;
    private String name;
    private String sex;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }
    @Column
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
    @Column
    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    @Override
    public String toString() {
        return "UserInfo{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", sex='" + sex + '\'' +
                '}';
    }
}

dao层:

package com.jpa.dao;

import com.jpa.bean.UserInfo;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;

import java.util.List;

/**JpaRepository<对象,主键类型>
 * Created by  lpw'ASUS on 2018/5/31.
 */
public interface UserInfoDao extends JpaRepository<UserInfo,Integer> {
    // 名字优于配置  @Quert vlaue 写jpql  ,且@Query优先级大于名字
//    @Query(value = "select u from UserInfo u where u.name like ?1")
//     List<UserInfo> findByName(String name);
     List<UserInfo> findByNameAndSex(String name,String sex);
     // 模糊查询
//     List<UserInfo> findByNameLike(String name);
    //分页查询,加模糊查询,
     Page<UserInfo> findByNameLike(String name, Pageable pageable);
}

测试类:

package com.jpa;

import com.jpa.bean.UserInfo;
import com.jpa.dao.UserInfoDao;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.List;

@RunWith(SpringRunner.class)
@SpringBootTest
public class JpaApplicationTests {

	@Autowired
	private UserInfoDao userInfoDao;
	@Test
	public void contextLoads() {
	}

	@Test
	public void insertTest(){
		UserInfo userInfo = new UserInfo();
		userInfo.setName("张三");
		userInfo.setSex("1");
		userInfoDao.save(userInfo);
	}

	@Test
	public void updateTest(){
		UserInfo userInfo = new UserInfo();
		userInfo.setName("李四");
		userInfo.setSex("0");
		userInfo.setId(1);
		userInfoDao.save(userInfo);
	}

	@Test
	public void deleteTest(){
		UserInfo userInfo = new UserInfo();
		userInfo.setId(1);
		userInfoDao.delete(userInfo);
	}

	@Test
	public void queryTest(){
//		UserInfo userInfo = new UserInfo();
//		userInfo.setName("张三");
//		userInfo.setSex("1");
//		List<UserInfo>  list= userInfoDao.findByName("%李%");
		List<UserInfo>  list1= userInfoDao.findByNameAndSex(userInfo.getName(),userInfo.getSex());
//
//		for(UserInfo user:list){
//			System.out.println("=="+user.toString());
//		}

//		for(UserInfo user:list1){
//			System.out.println("~~~~~"+user.toString());
//		}
	}


	@Test
	public void queryTest2(){
//
//		List<UserInfo>  list= userInfoDao.findByNameLike("%李%");
//
//		for(UserInfo user:list){
//			System.out.println("=="+user.toString());
//		}
	}

	@Test
	public void queryTest3(){
		Pageable pageable = new PageRequest(0,2);//第一个数0,代表第1页,2代表每页显示2条数据
               
		Page<UserInfo> page = userInfoDao.findByNameLike("%张%",pageable);

		for(UserInfo user:page.getContent()){
			System.out.println("=="+user.toString());
		}
	}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
### 回答1: 尚硅谷SpringBoot 2.0笔记: 1. 基于Java 8,支持Java 11 2. 内嵌Tomcat改为内嵌Jetty 3. 增强了对Spring5.0的支持 4. 增加了对Spring Security 5.0的支持 5. 提供了对Spring Data JPA的增强 6. 增加了对Spring WebFlux的支持 7. 支持Reactive编程 8. 支持Micrometer度量框架 9. 支持Spring Boot Actuator更新 10. 提供了更好的错误处理和调试支持。 ### 回答2: 尚硅谷的Spring Boot 2.0笔记是一份非常系统、详细的资料,包含了Spring Boot 2.0的核心内容及其应用,几乎覆盖了Spring Boot开发的所有方面。 首先,笔记中对于Spring Boot 2.0的基础知识和核心概念进行了详细的介绍,包括Spring Boot的起源、特点和优势,以及基于Spring Boot的开发模式和框架等。此外,笔记还对于Spring Boot 2.0的Maven依赖、配置文件和常用注解进行了讲解,让读者能够轻松上手开发、调试和测试Spring Boot应用程序。 其次,笔记中涵盖了Spring Boot的各种高级特性和应用场景,例如使用Spring Boot开发Web应用、构建RESTful API、使用Spring Boot实现事务控制和数据访问等。此外,笔记中还介绍了Spring Boot在微服务开发中的应用,包括使用Spring Cloud构建分布式架构、服务发现和注册、配置中心和熔断器等。 另外,笔记中还包含了大量的代码案例和实战演练,让读者能够深入理解Spring Boot的使用和开发技巧。同时,笔记还提供了一些最佳实践和调优技巧,让读者能够更加高效地开发和优化Spring Boot应用程序。 总之,尚硅谷Spring Boot 2.0笔记是一份非常有价值的资料,适合于所有对于Spring Boot开发感兴趣的人士。无论是初学者还是有经验的开发人员,都可以从中获取到大量的知识和实践经验,提高自己的技能水平和项目开发能力。 ### 回答3: 尚硅谷springboot2.0笔记是一份非常实用和全面的学习指导材料。它囊括了springboot2.0的各方面知识点,从基础到高级,从搭建环境到实际应用,都有详细而清晰的介绍和实例。 在学习springboot2.0之前,我们先了解一下什么是springboot。Spring Boot是Spring家族的一个全新项目,它通过提供各种有用的开箱即用的功能来简化Spring应用程序的开发和部署。因此,Spring Boot能够大大简化Web应用程序的开发,无需像以前那样手动配置各种组件,同时它的错误处理和日志记录等特性也非常实用。 尚硅谷springboot2.0笔记的内容非常丰富,其中包括了Spring Boot的介绍、搭建环境、基础用法、自动配置原理、Web开发、数据访问、消息服务、安全与监控等。除此之外,该笔记还详细讲解了常见的一些中间件的使用,比如Redis,RabbitMQ等。 与其他的学习资料相比,尚硅谷springboot2.0笔记的特点在于其结合了理论和实践,讲解清晰而且非常易于理解,并且笔记中的实例也非常实用,可以让读者更加深入的理解Spring Boot的各个方面。 总之,如果你想学习Spring Boot 2.0,尚硅谷springboot2.0笔记无疑是一个非常不错的选择。在学习的过程中,要不断动手实践,加深自己的理解,这样才能真正掌握这门技术。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值