0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

SpringBoot常用注解及使用方法2

jf_78858299 ? 來源:Java極客技術 ? 作者:鴨血粉絲Tang ? 2023-04-07 11:52 ? 次閱讀

2.3、JPA 相關注解

  • @Entity@Table

表明這是一個實體類,這兩個注解一般一塊使用,但是如果表名和實體類名相同的話,@Table可以省略。

  • @Id

表示該屬性字段對應數(shù)據(jù)庫表中的主鍵字段。

  • @Column

表示該屬性字段對應的數(shù)據(jù)庫表中的列名,如果字段名與列名相同,則可以省略。

  • @GeneratedValue

表示主鍵的生成策略,有四個選項,分別如下:

  • AUTO:表示由程序控制,是默認選項 ,不設置就是這個
  • IDENTITY:表示由數(shù)據(jù)庫生成,采用數(shù)據(jù)庫自增長,Oracle 不支持這種方式
  • SEQUENCE:表示通過數(shù)據(jù)庫的序列生成主鍵ID,MYSQL 不支持
  • Table:表示由特定的數(shù)據(jù)庫產生主鍵,該方式有利于數(shù)據(jù)庫的移植
  • @SequenceGeneretor

用來定義一個生成主鍵的序列,它需要與@GeneratedValue聯(lián)合使用才有效,以TB_ROLE表為例,對應的注解配置如下:

@Entity
@Table(name = "TB_ROLE")
@SequenceGenerator(name = "id_seq", sequenceName = "seq_repair",allocationSize = 1)
public class Role implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 主鍵ID,采用【id_seq】序列函數(shù)自增長
     */
    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE,generator = "id_seq")
    private Long id;


    /* 角色名稱
     */
    @Column(nullable = false)
    private String roleName;

    /**
     * 角色類型
     */
    @Column(nullable = false)
    private String roleType;
}
  • @Transient

表示該屬性并非與數(shù)據(jù)庫表的字段進行映射,ORM 框架會將忽略該屬性。

/**
 * 忽略該屬性
 */
@Column(nullable = false)
@Transient
private String lastTime;
  • @Basic(fetch=FetchType.LAZY)

用在某些屬性上,可以實現(xiàn)懶加載的效果,也就是當用到這個字段的時候,才會裝載這個屬性,如果配置成fetch=FetchType.EAGER,表示即時加載,也是默認的加載方式!

/**
 * 延遲加載該屬性
 */
@Column(nullable = false)
@Basic(fetch = FetchType.LAZY)
private String roleType;
  • @JoinColumn

用于標注表與表之間關系的字段,通常與@OneToOne@OneToMany搭配使用,例如如下

@Entity
@Table(name = "tb_login_log")
public class LoginLog implements Serializable {
 
 /**
  * 查詢登錄的用戶信息
  */
 @OneToOne
    @JoinColumn(name = "user_id")
    private User user;
 
 //...get、set
}
  • @OneToOne@OneToMany@ManyToOne

這三個注解,相當于hibernate配置文件中的一對一,一對多多對一配置,比如下面的客戶地址表,通過客戶 ID,實現(xiàn)客戶信息的查詢。

@Entity
@Table(name="address")
public class AddressEO implements java.io.Serializable {
 
  @ManyToOne(cascade = { CascadeType.ALL })
  @JoinColumn(name="customer_id")
  private CustomerEO customer;
 
  //...get、set
}

2.4、配置相關注解

  • @Configuration

表示聲明一個 Java 形式的配置類,Spring Boot 提倡基于 Java 的配置,相當于你之前在 xml 中配置 bean,比如聲明一個配置類AppConfig,然后初始化一個Uploader對象。

@Configuration
public class AppConfig {

    @Bean
    public Uploader initOSSUploader() {
        return new OSSUploader();
    }

}
  • @EnableAutoConfiguration

@EnableAutoConfiguration可以幫助SpringBoot應用將所有符合條件的@Configuration配置類,全部都加載到當前SpringBoot里,并創(chuàng)建對應配置類的Bean,并把該Bean實體交給IoC容器進行管理。

某些場景下,如果我們想要避開某些配置類的掃描(包括避開一些第三方jar包下面的配置,可以這樣處理。

@Configuration
@EnableAutoConfiguration(exclude = { org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class})
public class AppConfig {

 //具有業(yè)務方法
}
  • @ComponentScan

標注哪些路徑下的類需要被Spring掃描,用于自動發(fā)現(xiàn)和裝配一些Bean對象,默認配置是掃描當前文件夾下和子目錄下的所有類,如果我們想指定掃描某些包路徑,可以這樣處理。

@ComponentScan(basePackages = {"com.xxx.a", "com.xxx.b", "com.xxx.c"})
  • @SpringBootApplication

等價于使用@Configuration、@EnableAutoConfiguration@ComponentScan這三個注解,通常用于全局啟動類上,示例如下:

@SpringBootApplication
public class PropertyApplication {

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

@SpringBootApplication換成@Configuration@EnableAutoConfiguration、@ComponentScan這三個注解,一樣可以啟動成功,@SpringBootApplication只是將這三個注解進行了簡化!

  • @EnableTransactionManagement

表示開啟事務支持,等同于 xml 配置方式的

@SpringBootApplication
@EnableTransactionManagement`
public class PropertyApplication {

    public static void main(String[] args) {
        SpringApplication.run(PropertyApplication.class, args);
    }
}
  • @Conditional

從 Spring4 開始,可以通過@Conditional注解實現(xiàn)按條件裝載bean對象,目前 Spring Boot 源碼中大量擴展了@Condition注解,用于實現(xiàn)智能的自動化配置,滿足各種使用場景。下面我給大家列舉幾個常用的注解:

  • @ConditionalOnBean:當某個特定的Bean存在時,配置生效
  • @ConditionalOnMissingBean:當某個特定的Bean不存在時,配置生效
  • @ConditionalOnClass:當Classpath里存在指定的類,配置生效
  • @ConditionalOnMissingClass:當Classpath里不存在指定的類,配置生效
  • @ConditionalOnExpression:當給定的SpEL表達式計算結果為true,配置生效
  • @ConditionalOnProperty:當指定的配置屬性有一個明確的值并匹配,配置生效

具體的應用案例如下:

@Configuration
public class ConditionalConfig {


    /**
     * 當AppConfig對象存在時,創(chuàng)建一個A對象
     * @return
     */
    @ConditionalOnBean(AppConfig.class)
    @Bean
    public A createA(){
        return new A();
    }

    /**
     * 當AppConfig對象不存在時,創(chuàng)建一個B對象
     * @return
     */
    @ConditionalOnMissingBean(AppConfig.class)
    @Bean
    public B createB(){
        return new B();
    }


    /**
     * 當KafkaTemplate類存在時,創(chuàng)建一個C對象
     * @return
     */
    @ConditionalOnClass(KafkaTemplate.class)
    @Bean
    public C createC(){
        return new C();
    }

    /**
     * 當KafkaTemplate類不存在時,創(chuàng)建一個D對象
     * @return
     */
    @ConditionalOnMissingClass(KafkaTemplate.class)
    @Bean
    public D createD(){
        return new D();
    }


    /**
     * 當enableConfig的配置為true,創(chuàng)建一個E對象
     * @return
     */
    @ConditionalOnExpression("${enableConfig:false}")
    @Bean
    public E createE(){
        return new E();
    }


    /**
     * 當filter.loginFilter的配置為true,創(chuàng)建一個F對象
     * @return
     */
    @ConditionalOnProperty(prefix = "filter",name = "loginFilter",havingValue = "true")
    @Bean
    public F createF(){
        return new F();
    }
}
  • @value

可以在任意 Spring 管理的 Bean 中通過這個注解獲取任何來源配置的屬性值,比如你在application.properties文件里,定義了一個參數(shù)變量!

config.name=zhangsan

在任意的bean容器里面,可以通過@Value注解注入?yún)?shù),獲取參數(shù)變量值。

@RestController
public class HelloController {

    @Value("${config.name}")
    private String config;

    @GetMapping("config")
    public String config(){
        return JSON.toJSONString(config);
    }
}
  • @ConfigurationProperties

上面@Value在每個類中獲取屬性配置值的做法,其實是不推薦的。

一般在企業(yè)項目開發(fā)中,不會使用那么雜亂無章的寫法而且維護也麻煩,通常會一次性讀取一個 Java 配置類,然后在需要使用的地方直接引用這個類就可以多次訪問了,方便維護,示例如下:

首先,在application.properties文件里定義好參數(shù)變量。

config.name=demo_1
config.value=demo_value_1

然后,創(chuàng)建一個 Java 配置類,將參數(shù)變量注入即可!

@Component
@ConfigurationProperties(prefix = "config")
public class Config {

    public String name;

    public String value;

    //...get、set
}

最后,在需要使用的地方,通過ioc注入Config對象即可!

  • @PropertySource

這個注解是用來讀取我們自定義的配置文件的,比如導入test.propertiesbussiness.properties兩個配置文件,用法如下:

@SpringBootApplication
@PropertySource(value = {"test.properties","bussiness.properties"})
public class PropertyApplication {

    public static void main(String[] args) {
        SpringApplication.run(PropertyApplication.class, args);
    }
}
  • @ImportResource

用來加載 xml 配置文件,比如導入自定義的aaa.xml文件,用法如下:

@ImportResource(locations = "classpath:aaa.xml")
@SpringBootApplication
public class PropertyApplication {

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

2.5、異常處理相關注解

  • @ControllerAdvice@ExceptionHandler

通常組合使用,用于處理全局異常,示例代碼如下:

@ControllerAdvice
@Configuration
@Slf4j
public class GlobalExceptionConfig {
 
 private static final Integer GLOBAL_ERROR_CODE = 500;
 
 @ExceptionHandler(value = Exception.class)
    @ResponseBody
    public void exceptionHandler(HttpServletRequest request, HttpServletResponse response, Exception e) throws Exception {
        log.error("【統(tǒng)一異常處理器】", e);
        ResultMsg resultMsg = new ResultMsg<>();
        resultMsg.setCode(GLOBAL_ERROR_CODE);
        if (e instanceof CommonException) {
           CommonException ex = (CommonException) e;
           if(ex.getErrCode() != 0) {
                resultMsg.setCode(ex.getErrCode());
            }
            resultMsg.setMsg(ex.getErrMsg());
        }else {
            resultMsg.setMsg(CommonErrorMsg.SYSTEM_ERROR.getMessage());
        }
        WebUtil.buildPrintWriter(response, resultMsg);
    }
 
 
}

2.6、測試相關注解
@ActiveProfiles
一般作用于測試類上, 用于聲明生效的 Spring 配置文件,比如指定application-dev.properties配置文件。
@RunWith@SpringBootTest
一般作用于測試類上, 用于單元測試用,示例如下:
@ActiveProfiles("dev")
@RunWith(SpringRunner.class)
@SpringBootTest
public class TestJunit {

    @Test
    public void executeTask() {
        //測試...
    }
}

三、小結
整個篇幅內容比較多,比較干,大家在看的過程中,也沒有必要去記住,可以先收藏起來,等到需要用到的時候,再把它拿出來看看!
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • spring
    +關注

    關注

    0

    文章

    340

    瀏覽量

    14344
  • MVC
    MVC
    +關注

    關注

    0

    文章

    73

    瀏覽量

    13860
  • 開發(fā)者
    +關注

    關注

    1

    文章

    575

    瀏覽量

    17013
  • SpringBoot
    +關注

    關注

    0

    文章

    173

    瀏覽量

    180
收藏 人收藏

    評論

    相關推薦

    SpringBoot應用啟動運行run方法

    什么時候創(chuàng)建嵌入式的Servlet容器工廠?什么時候獲取嵌入式的Servlet容器并啟動Tomcat;獲取嵌入式的Servlet容器工廠:1)、SpringBoot應用啟動運行run方法2
    發(fā)表于 12-20 06:16

    HarmonyOS注解使用方法分享

    定義我們的注解自定義注解1、聲明注解功能:檢測類中是否有規(guī)范的get方法新建java libray的module,命名為annotation,創(chuàng)建
    發(fā)表于 03-28 14:04

    常用手機焊接工具使用方法

    常用手機焊接工具使用方法 主要學習以下幾點 1、掌握熱風槍和電烙鐵的使用方法。2、掌握手機小元件
    發(fā)表于 03-23 17:40 ?3.2w次閱讀

    示波器探頭常用附件的使用方法

    示波器探頭常用附件的使用方法
    發(fā)表于 01-22 13:38 ?25次下載

    Keil的使用方法 - 常用功能(二)

    Keil的使用方法 - 常用功能(二)
    的頭像 發(fā)表于 04-07 14:55 ?3322次閱讀
    Keil的<b class='flag-5'>使用方法</b> -  <b class='flag-5'>常用</b>功能(二)

    Keil的使用方法 - 常用功能(一)

    Keil的使用方法 - 常用功能(一)
    的頭像 發(fā)表于 04-07 14:51 ?8829次閱讀
    Keil的<b class='flag-5'>使用方法</b> -  <b class='flag-5'>常用</b>功能(一)

    Spring Boot常用注解與使用方式

    企業(yè)開發(fā)項目SpringBoot已經是必備框架了,其中注解是開發(fā)中的小工具(誰處可見哦),用好了開發(fā)效率大大提升,當然用錯了也會引入缺陷。
    的頭像 發(fā)表于 07-08 10:57 ?1374次閱讀

    SpringBoot常用注解使用方法1

    基于 SpringBoot 平臺開發(fā)的項目數(shù)不勝數(shù),與常規(guī)的基于`Spring`開發(fā)的項目最大的不同之處,SpringBoot 里面提供了大量的注解用于快速開發(fā),而且非常簡單,基本可以做到開箱即用! 那
    的頭像 發(fā)表于 04-07 11:51 ?707次閱讀

    Springboot常用注解合集

    前幾章,在系統(tǒng)啟動類里面,都加入了此啟動注解,此注解是個組合注解,包括了`@SpringBootConfiguration`、`@EnableAutoConfiguration`和`@ComponentScan`
    的頭像 發(fā)表于 04-07 14:27 ?735次閱讀
    <b class='flag-5'>Springboot</b><b class='flag-5'>常用</b><b class='flag-5'>注解</b>合集

    SpringBoot常用注解及原理

    SpringBootConfiguration繼承自@Configuration,二者功能也一致,標注當前類是配置類, 并會將當前類內聲明的一個或多個以@Bean注解標記的方法的實例納入到spring容器中,并且實例名就是方法
    的頭像 發(fā)表于 04-07 14:30 ?585次閱讀

    SpringBoot的核心注解1

    今天跟大家來探討下SpringBoot的核心注解@SpringBootApplication以及run方法,理解下springBoot為什么不需要XML,達到零配置
    的頭像 發(fā)表于 04-07 14:34 ?707次閱讀
    <b class='flag-5'>SpringBoot</b>的核心<b class='flag-5'>注解</b>1

    SpringBoot的核心注解2

    今天跟大家來探討下SpringBoot的核心注解@SpringBootApplication以及run方法,理解下springBoot為什么不需要XML,達到零配置
    的頭像 發(fā)表于 04-07 14:34 ?1966次閱讀
    <b class='flag-5'>SpringBoot</b>的核心<b class='flag-5'>注解</b><b class='flag-5'>2</b>

    springmvc常用5種注解

    SpringMVC是一種基于Java的Web框架,使用注解可以更加方便靈活地開發(fā)和管理控制器,實現(xiàn)請求的映射和處理。在SpringMVC中,有許多常用注解,本文將詳細介紹其中的五種注解
    的頭像 發(fā)表于 11-22 16:51 ?902次閱讀

    springboot核心注解

    幫助開發(fā)者簡化開發(fā)過程,提高開發(fā)效率。本文將深入介紹 Spring Boot 的核心注解及其使用方法。 @SpringBootApplication @SpringBootApplication
    的頭像 發(fā)表于 11-23 09:23 ?527次閱讀

    SpringBoot核心注解由幾個注解組成

    簡化應用程序開發(fā)的注解,其中核心注解包括 @SpringBootApplication、@RestController、@RequestMapping、@Autowired、@ComponentScan
    的頭像 發(fā)表于 12-03 15:09 ?762次閱讀