• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Java > SpringBoot入门系列之JPA mysql

SpringBoot入门系列之JPA mysql

作者:sosfnima 字体:[增加 减小] 来源:互联网 时间:2017-05-28

sosfnima 通过本文主要向大家介绍了springboot jpa,springboot整合jpa,springboot jpa 分页,springboot jpa配置,springboot 使用jpa等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

一,准备工作,建立spring-boot-sample-mysql工程

1、http://start.spring.io/

     A、Artifact中输入spring-boot-sample-MySQL
     B、勾选Web下的web
     C、勾选SQL下的JPA MYSQL

2、Eclips中导入工程spring-boot-sample-mysql

     A、解压快捷工程spring-boot-sample-mysql到某文件夹

     B、eclips中file->import->Import Existing Maven Projects-->Select Maven projects-->finish导入工程

3、工程导入之后,文件结构如下图

4、在包com.example下建立web文件夹

5、便于测试,引入spring-boot-sample-helloworld的HelloController及配置文件logback.xml

HelloController代码为

package com.example.web; 
import org.slf4j.Logger; 
import org.slf4j.LoggerFactory; 
import org.springframework.web.bind.annotation.PathVariable; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.RestController; 
@RestController 
public class HelloController { 
  protected static Logger logger=LoggerFactory.getLogger(HelloController.class); 
  @RequestMapping("/") 
  public String helloworld(){ 
    logger.debug("访问hello"); 
    return "Hello world!"; 
  } 
  @RequestMapping("/hello/{name}") 
  public String helloName(@PathVariable String name){ 
    logger.debug("访问helloName,Name={}",name); 
    return "Hello "+name; 
  } 
} 
</div>

logback.xml配置为

<configuration>  
  <!-- %m输出的信息,%p日志级别,%t线程名,%d日期,%c类的全名,,,, -->  
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">  
    <encoder>  
      <pattern>%d %p (%file:%line\)- %m%n</pattern> 
      <charset>GBK</charset>  
    </encoder>  
  </appender>  
  <appender name="baselog"  
    class="ch.qos.logback.core.rolling.RollingFileAppender">  
    <File>log/base.log</File>  
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
      <fileNamePattern>log/base.log.%d.i%</fileNamePattern>  
      <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">  
        <!-- or whenever the file size reaches 64 MB -->  
        <maxFileSize>64 MB</maxFileSize>  
      </timeBasedFileNamingAndTriggeringPolicy>  
    </rollingPolicy>  
    <encoder>  
      <pattern>  
        %d %p (%file:%line\)- %m%n 
      </pattern>  
      <charset>UTF-8</charset> <!-- 此处设置字符集 -->  
    </encoder>  
  </appender>  
  <root level="info">  
    <appender-ref ref="STDOUT" />  
  </root>  
  <logger name="com.example" level="DEBUG">  
    <appender-ref ref="baselog" />  
  </logger>  
</configuration> 
</div>

注:logback.xml文件位于src/main/resources下

6、启动工程,通过浏览器查看正确性

http://localhost:8080/

http://localhost:8080/hello/上帝

二,使用JPA,构建业务对象及访问库

1、在包com.example下建立domain文件夹

2、在domain中建立类Person

package com.example.domain; 
import javax.persistence.Entity; 
import javax.persistence.GeneratedValue; 
import javax.persistence.Id; 
@Entity 
public class Person { 
  @Id 
  @GeneratedValue 
  private Long id; 
  private String name; 
  private Integer age; 
  private String address; 
  public Person() { 
    super(); 
  } 
  public Person(Long id, String name, Integer age, String address) { 
    super(); 
    this.id = id; 
    this.name = name; 
    this.age = age; 
    this.address = address; 
  } 
  public Long getId() { 
    return id; 
  } 
  public void setId(Long id) { 
    this.id = id; 
  } 
  public String getName() { 
    return name; 
  } 
  public void setName(String name) { 
    this.name = name; 
  } 
  public Integer getAge() { 
    return age; 
  } 
  public void setAge(Integer age) { 
    this.age = age; 
  } 
  public String getAddress() { 
    return address; 
  } 
  public void setAddress(String address) { 
    this.address = address; 
  } 
} 
</div>

注意:构造函数

3、在包com.example下建立repository文件夹

4、在repository中建立接口PersonRepository

package com.example.repository; 
import java.util.List; 
import org.springframework.data.jpa.repository.JpaRepository; 
import org.springframework.data.jpa.repository.Query; 
import org.springframework.data.repository.query.Param; 
import org.springframework.stereotype.Repository; 
import com.example.domain.Person; 
@Repository 
public interface PersonRepository extends JpaRepository<Person,Long> { 
  List<Person> findByName(String name); 
  List<Person> findByAddress(String address); 
  List<Person> findByNameAndAddress(String name,String address); 
  @Query("select p from Person p where p.name=:name and p.address=:address") 
  List<Person> withNameAndAddressQuery(@Param("name")String Name,@Param("address")String address); 
} 
</div>

5、在web中建立DataController

package com.example.web; 
import java.util.List; 
import org.slf4j.Logger; 
import org.slf4j.LoggerFactory; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.data.domain.Page; 
import org.springframework.data.domain.PageRequest; 
import org.springframework.data.domain.Sort; 
import org.springframework.data.domain.Sort.Direction; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.RestController; 
import com.example.domain.Person; 
import com.example.repository.PersonRepository; 
@RestController 
public class DataController { 
  protected static Logger logger=LoggerFactory.getLogger(DataController.class); 
  @Autowired 
  PersonRepository personRepository; 
  @RequestMapping("/save") 
  public Person save(String name,String address,Integer age){ 
    logger.debug("save 开始"); 
    Person p=personRepository.save(new Person(null,name,age,address)); 
    logger.debug("save 结束"); 
    return p; 
  } 
  @RequestMapping("/q1") 
  public List<Person> q1(String address){ 
    logger.debug("q1 开始"); 
    logger.debug("q1 接收参数address={}",address); 
    List<Person> people=personRepository.findByAddress(address); 
    return people; 
  } 
  @RequestMapping("/q2") 
  public List<Person> q2(String name,String address){ 
    logger.debug("q2 开始"); 
    logger.debug("q2接收参数name={},address={}",name,address); 
    return personRepository.findByNameAndAddress(name, address); 
  } 
  @RequestMapping("/q3") 
  public List<Person> q3(String name,String address){ 
    logger.debug("q3 开始"); 
    logger.debug("q3接收参数name={},address={}",name,address); 
    return personRepository.withNameAndAddressQuery(name, address); 
  } 
  @RequestMapping("/sort") 
  public List<Person> sort(){ 
    logger.debug("sort 开始"); 
    List<Person> people=personRepository.findAll(new Sort(Direction.ASC,"age")); 
    return people; 
  } 
  @RequestMapping("/page") 
  public Page<Person> pag



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • SpringBoot整合JPA的实例代码
  • SpringBoot集成Spring Data JPA及读写分离
  • SpringBoot JPA 表关联查询实例
  • SpringBoot入门系列之JPA mysql
  • 详解SpringBoot Schedule配置
  • SpringBoot整合JPA的实例代码
  • SpringBoot集成Spring Data JPA及读写分离
  • SpringBoot JPA 表关联查询实例

相关文章

  • 2017-05-28java统计汉字字数的方法示例
  • 2017-05-28详解Java从后台重定向(redirect)到另一个项目的方法
  • 2017-05-28struts2如何使用拦截器进行用户权限控制实例
  • 2017-05-28Java实现在不同线程中运行的代码实例
  • 2017-05-28Java——对象初始化顺序使用详解
  • 2017-05-28Spring boot实现文件上传实例(多文件上传)
  • 2017-05-28详解springMVC之与json数据交互方法
  • 2017-05-28spring mvc+localResizeIMG实现HTML5端图片压缩上传
  • 2017-05-28JVM(Java虚拟机)简介(动力节点Java学院整理)
  • 2017-05-28SpringMvc+Angularjs 实现多文件批量上传

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • java实现合并单元格的同时并导出excel示例
    • Java 线程优先级详解及实例
    • Java本地缓存的实现代码
    • Spring Boot如何解决Mysql断连问题
    • C#创建Web应用程序代码实例
    • java 请求跨域问题解决方法实例详解
    • java数据结构与算法之桶排序实现方法详解
    • Spring 使用注解方式进行事务管理配置方式
    • Lambda表达式和Java集合框架
    • Java网络通信基础编程(必看篇)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有