成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Springboot整合GraphQL使你的API更易理解可讀性更強

開發 開發工具
GraphQL API 基于類型和字段的方式進行組織,而非入口端點。你可以通過一個單一入口端點得到你所有的數據能力。GraphQL 使用類型來保證應用只請求可能的數據,還提供了清晰的輔助性錯誤信息。

環境:Springboot3.0.9

概述

  • 一種用于 API 的查詢語言

GraphQL 既是一種用于 API 的查詢語言也是一個滿足你數據查詢的運行時。GraphQL 對你的 API 中的數據提供了一套易于理解的完整描述,使得客戶端能夠準確地獲得它需要的數據,而且沒有任何冗余,也讓 API 更容易地隨著時間推移而演進,還能用于構建強大的開發者工具。

  • 請求你所要的數據

向你的 API 發出一個 GraphQL 請求就能準確獲得你想要的數據,不多不少。GraphQL 查詢總是返回可預測的結果。使用 GraphQL 的應用可以工作得又快又穩,因為控制數據的是應用,而不是服務器。

  • 獲取多個資源

GraphQL 查詢不僅能夠獲得資源的屬性,還能沿著資源間引用進一步查詢。典型的 REST API 請求多個資源時得載入多個 URL,而 GraphQL 可以通過一次請求就獲取你應用所需的所有數據。這樣一來,即使是比較慢的移動網絡連接下,使用 GraphQL 的應用也能表現得足夠迅速。

  • 描述所有的可能

GraphQL API 基于類型和字段的方式進行組織,而非入口端點。你可以通過一個單一入口端點得到你所有的數據能力。GraphQL 使用類型來保證應用只請求可能的數據,還提供了清晰的輔助性錯誤信息。應用可以使用類型,而避免編寫手動解析代碼。

有關GraphQL的語法相關知識,請參考

https://graphql.org/中文

https://graphql.cn/

接下來將以一個完整的示例演示GraphQL的使用。

環境配置

  • 引入依賴
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-graphql</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>com.mysql</groupId>
  <artifactId>mysql-connector-j</artifactId>
  <scope>runtime</scope>
</dependency>
  • 配置文件
spring:
  datasource:
    driverClassName: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/testjpa?serverTimezone=GMT%2B8&nullCatalogMeansCurrent=true&useSSL=false
    username: root
    password: xxxxxx
    type: com.zaxxer.hikari.HikariDataSource
    hikari:
      minimumIdle: 10
      maximumPoolSize: 200
      autoCommit: true
      idleTimeout: 30000
      poolName: MasterDatabookHikariCP
      maxLifetime: 1800000
      connectionTimeout: 30000
      connectionTestQuery: SELECT 1  
---
spring:
  jpa:
    generateDdl: false
    hibernate:
      ddlAuto: update
    openInView: true
    show-sql: true
---
spring:
  graphql:
    path: /graphql
    graphiql:
      enabled: true
      path: /graphiql
    cors:
      allow-credentials: true
      allowed-headers: '*'
      allowed-methods: '*'
    schema:
      locations:
      - classpath*:graphql/**/
      file-extensions:
      - .graphqls
      - .gqls
      printer:
        enabled: true

注意:這里的
spring.graphql.graphql.enabled=true開啟后,將會提供一個UI界面供我們快速查詢測試使用

圖片圖片

做好以上配置后,接下來就是建立2張表t_book和t_author。

實體定義

Book

@Entity
@Table(name = "t_book")
public class Book {


  @Id
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private Long id ;
  private String name ;
  private Integer pageCount ;
  @Transient
  private List<Author> author = new ArrayList<>();
}

Author

@Entity
@Table(name = "t_author")
public class Author {
  
  @Id
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private Long id ;
  private String firstName ;
  private String lastName ;
  // Book表的主鍵
  private Long bid ;
}

Repository定義

BookRepository

public interface BookRepository extends JpaRepository<Book, Long>, JpaSpecificationExecutor<Book> {
}

AuthorRepository

public interface AuthorRepository extends JpaRepository<Author, Long>, JpaSpecificationExecutor<Author> {


  List<Author> findByBid(Long bid) ;
  
}

Service定義

@Service
public class BookService {
  
  @Resource
  private BookRepository bookRepository ;
  @Resource
  private AuthorRepository authorRepository ;
  
  public Book queryBook(Long id) {
    Book book = bookRepository.findById(id).orElse(null) ;
    List<Author> authors = authorRepository.findByBid(id) ;
    book.setAuthor(authors) ;
    return book ;
  }
  
}

以上是基本的數據庫操作,很容易理解。接下來就是定義GraphQL Schema

GraphQL Schema定義

schema {
  query: BookQuery
}


type BookQuery {
  bookById(id: ID): Book
}


type Book {
  id: ID
  name: String
  pageCount: Int
  author: [Author]
}


type Author {
  id: ID
  firstName: String
  lastName: String
}

有關graphql相關語法請參考上面提到的網址。接下來是定義訪問接口

Controller接口

@Controller
public class BookController {


  @Resource
  private BookService bookService;
  @Resource
  private AuthorRepository authorRepository;


  @SchemaMapping(typeName = "BookQuery", field = "bookById")
  public Book bookById(@Argument Long id) {
    return bookService.queryBook(id);
  }


}

訪問測試

只需訪問統一的入口即可:

#該訪問路徑可以在配置文件中修改

http://localhost:8080/graphql

圖片圖片


這里是訪問的完整的信息,我們可以在請求的query中設置需要訪問的字段,如下:

圖片圖片

只訪問book信息

只訪問部分字段信息只訪問部分字段信息

你需要訪問那些字段,是完全由客戶端定義的。

責任編輯:武曉燕 來源: 實戰案例錦集
相關推薦

2023-09-11 09:38:25

代碼編程

2021-10-09 10:24:53

Java 代碼可讀性

2017-10-30 15:22:29

代碼可讀性技巧

2021-04-01 16:43:05

代碼可讀性開發

2019-06-06 08:48:14

代碼函數編程語言

2015-08-27 13:11:18

JavaScript代碼

2021-01-26 09:18:27

Shell腳本網站

2024-04-23 08:01:20

面向對象C 語言代碼

2021-12-08 23:38:25

Python工具代碼

2024-08-02 16:20:06

2017-12-19 16:24:20

2022-08-29 00:37:53

Python技巧代碼

2022-08-23 14:57:43

Python技巧函數

2021-06-15 09:12:19

TypeScriptTypeScript Javascript

2020-11-08 14:36:27

pandas數據分析pipe()

2022-11-04 11:18:16

代碼優化可讀性

2019-12-03 09:32:32

JavaScript代碼開發

2024-01-31 08:04:43

PygmentsPython

2014-07-29 09:55:33

程序員代碼可讀性

2014-07-28 10:28:25

程序員
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲三级免费看 | 国产精品明星裸体写真集 | 久久综合888 | 91麻豆精品国产91久久久久久久久 | 国产免费一区二区三区网站免费 | 欧美一区2区三区4区公司 | 国产夜恋视频在线观看 | 亚洲精品久久久 | 国产精品中文字幕在线 | 国产精品久久久久久久久免费樱桃 | 超级黄色一级片 | 韩国av一区二区 | 亚洲成人国产精品 | 日日摸夜夜爽人人添av | 香蕉视频在线播放 | 一级视频在线免费观看 | 久久精品久久综合 | 精品国产乱码久久久久久中文 | 日韩欧美精品一区 | 在线观看中文字幕视频 | www.久久久久久久久久久久 | 中文字幕日韩欧美 | 久久精品一区二 | 免费一区二区 | 国产在线精品一区二区 | 久久三级影院 | 中文字幕一区在线观看视频 | 久久久免费毛片 | 91精品国产一区二区三区 | 久久精品国产免费看久久精品 | 综合久久99| 国产成人精品一区二区三区网站观看 | 欧美一区二区在线 | 范冰冰一级做a爰片久久毛片 | 精品一区二区三区不卡 | 韩日一区二区三区 | 国产色网| 激情网站 | 日韩视频在线一区 | 伊人二区 | 精品日韩 |