欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis教程之增刪改查_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

 更新時(shí)間:2017年09月05日 11:09:03   作者:limingnihao  
這篇文章主要介紹了mybatis教程之增刪改查,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

select

一個(gè)select 元素非常簡(jiǎn)單。例如:

<!-- 查詢(xún)學(xué)生,根據(jù)id --> 
<select id="getStudent" parameterType="String" resultMap="studentResultMap"> 
  SELECT ST.STUDENT_ID, 
        ST.STUDENT_NAME, 
        ST.STUDENT_SEX, 
        ST.STUDENT_BIRTHDAY, 
        ST.CLASS_ID 
     FROM STUDENT_TBL ST 
     WHERE ST.STUDENT_ID = #{studentID} 
</select> 

這條語(yǔ)句就叫做‘getStudent,有一個(gè)String參數(shù),并返回一個(gè)StudentEntity類(lèi)型的對(duì)象。

注意參數(shù)的標(biāo)識(shí)是:#{studentID}。

select 語(yǔ)句屬性配置細(xì)節(jié): 

屬性
描述
取值
默認(rèn)
id
在這個(gè)模式下唯一的標(biāo)識(shí)符,可被其它語(yǔ)句引用
 
 
parameterType
傳給此語(yǔ)句的參數(shù)的完整類(lèi)名或別名
 
 
resultType
語(yǔ)句返回值類(lèi)型的整類(lèi)名或別名。注意,如果是集合,那么這里填寫(xiě)的是集合的項(xiàng)的整類(lèi)名或別名,而不是集合本身的類(lèi)名。(resultType 與resultMap 不能并用)
 
 
resultMap
引用的外部resultMap 名。結(jié)果集映射是MyBatis 中最強(qiáng)大的特性。許多復(fù)雜的映射都可以輕松解決。(resultType 與resultMap 不能并用)
 
 
flushCache
如果設(shè)為true,則會(huì)在每次語(yǔ)句調(diào)用的時(shí)候就會(huì)清空緩存。select 語(yǔ)句默認(rèn)設(shè)為false
true|false
false
useCache
如果設(shè)為true,則語(yǔ)句的結(jié)果集將被緩存。select 語(yǔ)句默認(rèn)設(shè)為false true|false false
timeout 設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
true|false
false
timeout 
設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
正整數(shù)
未設(shè)置
fetchSize
設(shè)置一個(gè)值后,驅(qū)動(dòng)器會(huì)在結(jié)果集數(shù)目達(dá)到此數(shù)值后,激發(fā)返回,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
正整數(shù)
驅(qū)動(dòng)器決定
statementType
statement,preparedstatement,callablestatement。
預(yù)準(zhǔn)備語(yǔ)句、可調(diào)用語(yǔ)句
STATEMENT
PREPARED
CALLABLE
PREPARED
resultSetType
forward_only,scroll_sensitive,scroll_insensitive
只轉(zhuǎn)發(fā),滾動(dòng)敏感,不區(qū)分大小寫(xiě)的滾動(dòng)
FORWARD_ONLY
SCROLL_SENSITIVE
SCROLL_INSENSITIVE
驅(qū)動(dòng)器決定

insert

一個(gè)簡(jiǎn)單的insert語(yǔ)句:

<!-- 插入學(xué)生 --> 
<insert id="insertStudent" parameterType="StudentEntity"> 
    INSERT INTO STUDENT_TBL (STUDENT_ID, 
                     STUDENT_NAME, 
                     STUDENT_SEX, 
                     STUDENT_BIRTHDAY, 
                     CLASS_ID) 
       VALUES  (#{studentID}, 
             #{studentName}, 
             #{studentSex}, 
             #{studentBirthday}, 
             #{classEntityclassID}) 
</insert> 

insert可以使用數(shù)據(jù)庫(kù)支持的自動(dòng)生成主鍵策略,設(shè)置useGeneratedKeys=”true”,然后把keyProperty 設(shè)成對(duì)應(yīng)的列,就搞定了。比如說(shuō)上面的StudentEntity 使用auto-generated 為id 列生成主鍵.

還可以使用selectKey元素。下面例子,使用mysql數(shù)據(jù)庫(kù)nextval('student')為自定義函數(shù),用來(lái)生成一個(gè)key。 

<!-- 插入學(xué)生 自動(dòng)主鍵--> 
<insert id="insertStudentAutoKey" parameterType="StudentEntity"> 
  <selectKey keyProperty="studentID" resultType="String" order="BEFORE"> 
      select nextval('student') 
  </selectKey> 
    INSERT INTO STUDENT_TBL (STUDENT_ID, 
                 STUDENT_NAME, 
                 STUDENT_SEX, 
                 STUDENT_BIRTHDAY, 
                 CLASS_ID) 
       VALUES  (#{studentID}, 
            #{studentName}, 
            #{studentSex}, 
            #{studentBirthday}, 
            #{classEntityclassID})   
</insert> 

insert語(yǔ)句屬性配置細(xì)節(jié):

屬性
描述
取值
默認(rèn)
id
在這個(gè)模式下唯一的標(biāo)識(shí)符,可被其它語(yǔ)句引用
 
 
parameterType
傳給此語(yǔ)句的參數(shù)的完整類(lèi)名或別名
 
 
flushCache
如果設(shè)為true,則會(huì)在每次語(yǔ)句調(diào)用的時(shí)候就會(huì)清空緩存。select 語(yǔ)句默認(rèn)設(shè)為false
true|false
false
useCache
如果設(shè)為true,則語(yǔ)句的結(jié)果集將被緩存。select 語(yǔ)句默認(rèn)設(shè)為false true|false false
timeout 設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
true|false
false
timeout 
設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
正整數(shù)
未設(shè)置
fetchSize
設(shè)置一個(gè)值后,驅(qū)動(dòng)器會(huì)在結(jié)果集數(shù)目達(dá)到此數(shù)值后,激發(fā)返回,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
正整數(shù)
驅(qū)動(dòng)器決定
statementType
statement,preparedstatement,callablestatement。
預(yù)準(zhǔn)備語(yǔ)句、可調(diào)用語(yǔ)句
STATEMENT
PREPARED
CALLABLE
PREPARED
useGeneratedKeys
告訴MyBatis 使用JDBC 的getGeneratedKeys 方法來(lái)獲取數(shù)據(jù)庫(kù)自己生成的主鍵(MySQL、SQLSERVER 等
關(guān)系型數(shù)據(jù)庫(kù)會(huì)有自動(dòng)生成的字段)。默認(rèn):false
true|false
false
keyProperty
標(biāo)識(shí)一個(gè)將要被MyBatis 設(shè)置進(jìn)getGeneratedKeys 的key 所返回的值,或者為insert 語(yǔ)句使用一個(gè)selectKey
子元素。
 

selectKey語(yǔ)句屬性配置細(xì)節(jié):

屬性
描述
取值
keyProperty
selectKey 語(yǔ)句生成結(jié)果需要設(shè)置的屬性。
 
resultType
生成結(jié)果類(lèi)型,MyBatis 允許使用基本的數(shù)據(jù)類(lèi)型,包括String 、int類(lèi)型。
 
order
可以設(shè)成BEFORE 或者AFTER,如果設(shè)為BEFORE,那它會(huì)先選擇主鍵,然后設(shè)置keyProperty,再執(zhí)行insert語(yǔ)句;如果設(shè)為AFTER,它就先運(yùn)行insert 語(yǔ)句再運(yùn)行selectKey 語(yǔ)句,通常是insert 語(yǔ)句中內(nèi)部調(diào)用數(shù)據(jù)庫(kù)(像Oracle)內(nèi)嵌的序列機(jī)制。 
BEFORE
AFTER
statementType
像上面的那樣, MyBatis 支持STATEMENT,PREPARED和CALLABLE 的語(yǔ)句形式, 對(duì)應(yīng)Statement ,PreparedStatement 和CallableStatement 響應(yīng)
STATEMENT
PREPARED
CALLABLE

update、delete

一個(gè)簡(jiǎn)單的update: 

<!-- 更新學(xué)生信息 --> 
<update id="updateStudent" parameterType="StudentEntity"> 
    UPDATE STUDENT_TBL 
      SET STUDENT_TBL.STUDENT_NAME = #{studentName},  
        STUDENT_TBL.STUDENT_SEX = #{studentSex}, 
        STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday}, 
        STUDENT_TBL.CLASS_ID = #{classEntity.classID} 
     WHERE STUDENT_TBL.STUDENT_ID = #{studentID};   
</update> 

一個(gè)簡(jiǎn)單的delete:

<!-- 刪除學(xué)生 --> 
<delete id="deleteStudent" parameterType="StudentEntity"> 
    DELETE FROM STUDENT_TBL WHERE STUDENT_ID = #{studentID} 
</delete> 

update、delete語(yǔ)句屬性配置細(xì)節(jié):

屬性
描述
取值
默認(rèn)
id
在這個(gè)模式下唯一的標(biāo)識(shí)符,可被其它語(yǔ)句引用
 
 
parameterType
傳給此語(yǔ)句的參數(shù)的完整類(lèi)名或別名
 
 
flushCache
如果設(shè)為true,則會(huì)在每次語(yǔ)句調(diào)用的時(shí)候就會(huì)清空緩存。select 語(yǔ)句默認(rèn)設(shè)為false
true|false
false
useCache
如果設(shè)為true,則語(yǔ)句的結(jié)果集將被緩存。select 語(yǔ)句默認(rèn)設(shè)為false true|false false
timeout 設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
true|false
false
timeout 
設(shè)置驅(qū)動(dòng)器在拋出異常前等待回應(yīng)的最長(zhǎng)時(shí)間,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
正整數(shù)
未設(shè)置
fetchSize
設(shè)置一個(gè)值后,驅(qū)動(dòng)器會(huì)在結(jié)果集數(shù)目達(dá)到此數(shù)值后,激發(fā)返回,默認(rèn)為不設(shè)值,由驅(qū)動(dòng)器自己決定
正整數(shù)
驅(qū)動(dòng)器決定
statementType
statement,preparedstatement,callablestatement。
預(yù)準(zhǔn)備語(yǔ)句、可調(diào)用語(yǔ)句
STATEMENT
PREPARED
CALLABLE
PREPARED

sql

Sql元素用來(lái)定義一個(gè)可以復(fù)用的SQL 語(yǔ)句段,供其它語(yǔ)句調(diào)用。比如:

<!-- 復(fù)用sql語(yǔ)句 查詢(xún)student表所有字段 --> 
<sql id="selectStudentAll"> 
    SELECT ST.STUDENT_ID, 
          ST.STUDENT_NAME, 
          ST.STUDENT_SEX, 
          ST.STUDENT_BIRTHDAY, 
          ST.CLASS_ID 
       FROM STUDENT_TBL ST 
</sql> 

這樣,在select的語(yǔ)句中就可以直接引用使用了,將上面select語(yǔ)句改成:

<!-- 查詢(xún)學(xué)生,根據(jù)id --> 
<select id="getStudent" parameterType="String" resultMap="studentResultMap"> 
  <include refid="selectStudentAll"/> 
      WHERE ST.STUDENT_ID = #{studentID}  
</select> 

parameters

上面很多地方已經(jīng)用到了參數(shù),比如查詢(xún)、修改、刪除的條件,插入,修改的數(shù)據(jù)等,MyBatis可以使用的基本數(shù)據(jù)類(lèi)型和Java的復(fù)雜數(shù)據(jù)類(lèi)型。

基本數(shù)據(jù)類(lèi)型,String,int,date等。

但是使用基本數(shù)據(jù)類(lèi)型,只能提供一個(gè)參數(shù),所以需要使用Java實(shí)體類(lèi),或Map類(lèi)型做參數(shù)類(lèi)型。通過(guò)#{}可以直接得到其屬性。

基本類(lèi)型參數(shù)

根據(jù)入學(xué)時(shí)間,檢索學(xué)生列表:

<!-- 查詢(xún)學(xué)生list,根據(jù)入學(xué)時(shí)間 --> 
<select id="getStudentListByDate" parameterType="Date" resultMap="studentResultMap"> 
  SELECT * 
   FROM STUDENT_TBL ST LEFT JOIN CLASS_TBL CT ON ST.CLASS_ID = CT.CLASS_ID 
   WHERE CT.CLASS_YEAR = #{classYear};   
</select> 
List<StudentEntity> studentList = studentMapper.getStudentListByClassYear(StringUtil.parse("2007-9-1")); 
for (StudentEntity entityTemp : studentList) { 
  System.out.println(entityTemp.toString()); 
} 

Java實(shí)體類(lèi)型參數(shù)

根據(jù)姓名和性別,檢索學(xué)生列表。使用實(shí)體類(lèi)做參數(shù):

<!-- 查詢(xún)學(xué)生list,like姓名、=性別,參數(shù)entity類(lèi)型 --> 
<select id="getStudentListWhereEntity" parameterType="StudentEntity" resultMap="studentResultMap"> 
  SELECT * from STUDENT_TBL ST 
    WHERE ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%') 
     AND ST.STUDENT_SEX = #{studentSex} 
</select> 
StudentEntity entity = new StudentEntity(); 
entity.setStudentName("李"); 
entity.setStudentSex("男"); 
List<StudentEntity> studentList = studentMapper.getStudentListWhereEntity(entity); 
for (StudentEntity entityTemp : studentList) { 
  System.out.println(entityTemp.toString()); 
} 

Map參數(shù)

根據(jù)姓名和性別,檢索學(xué)生列表。使用Map做參數(shù): 

<!-- 查詢(xún)學(xué)生list,=性別,參數(shù)map類(lèi)型 --> 
<select id="getStudentListWhereMap" parameterType="Map" resultMap="studentResultMap"> 
  SELECT * from STUDENT_TBL ST 
   WHERE ST.STUDENT_SEX = #{sex} 
     AND ST.STUDENT_SEX = #{sex} 
</select> 
Map<String, String> map = new HashMap<String, String>(); 
map.put("sex", "女"); 
map.put("name", "李"); 
List<StudentEntity> studentList = studentMapper.getStudentListWhereMap(map); 
for (StudentEntity entityTemp : studentList) { 
  System.out.println(entityTemp.toString()); 
} 

多參數(shù)的實(shí)現(xiàn) 

如果想傳入多個(gè)參數(shù),則需要在接口的參數(shù)上添加@Param注解。給出一個(gè)實(shí)例:

接口寫(xiě)法:

復(fù)制代碼 代碼如下:
  
public List<StudentEntity> getStudentListWhereParam(@Param(value = "name") String name, @Param(value = "sex") String sex, @Param(value = "birthday") Date birthdar, @Param(value = "classEntity") ClassEntity classEntity);  
 

SQL寫(xiě)法:

<!-- 查詢(xún)學(xué)生list,like姓名、=性別、=生日、=班級(jí),多參數(shù)方式 --> 
<select id="getStudentListWhereParam" resultMap="studentResultMap"> 
  SELECT * from STUDENT_TBL ST 
  <where> 
    <if test="name!=null and name!='' "> 
      ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{name}),'%') 
    </if> 
    <if test="sex!= null and sex!= '' "> 
      AND ST.STUDENT_SEX = #{sex} 
    </if> 
    <if test="birthday!=null"> 
      AND ST.STUDENT_BIRTHDAY = #{birthday} 
    </if> 
    <if test="classEntity!=null and classEntityclassID !=null and classEntityclassID!='' "> 
      AND ST.CLASS_ID = #{classEntity.classID} 
    </if> 
  </where> 
</select> 
 

進(jìn)行查詢(xún):

List<StudentEntity> studentList = studentMapper.getStudentListWhereParam("", "",StringUtil.parse("1985-05-28"), classMapper.getClassByID("20000002")); 
for (StudentEntity entityTemp : studentList) { 
  System.out.println(entityTemp.toString()); 
} 

字符串代入法

默認(rèn)的情況下,使用#{}語(yǔ)法會(huì)促使MyBatis 生成PreparedStatement 屬性并且使用PreparedStatement 的參數(shù)(=?)來(lái)安全的設(shè)置值。盡量這些是快捷安全,也是經(jīng)常使用的。但有時(shí)候你可能想直接未更改的字符串代入到SQL 語(yǔ)句中。比如說(shuō),對(duì)于ORDER BY,你可能會(huì)這樣使用:ORDER BY ${columnName}但MyBatis 不會(huì)修改和規(guī)避掉這個(gè)字符串。

注意:這樣地接收和應(yīng)用一個(gè)用戶(hù)輸入到未更改的語(yǔ)句中,是非常不安全的。這會(huì)讓用戶(hù)能植入破壞代碼,所以,要么要求字段不要允許客戶(hù)輸入,要么你直接來(lái)檢測(cè)他的合法性 。

cache緩存

MyBatis 包含一個(gè)強(qiáng)在的、可配置、可定制的緩存機(jī)制。MyBatis 3 的緩存實(shí)現(xiàn)有了許多改進(jìn),既強(qiáng)勁也更容易配置。默認(rèn)的情況,緩存是沒(méi)有開(kāi)啟,除了會(huì)話緩存以外,它可以提高性能,且能解決全局依賴(lài)。開(kāi)啟二級(jí)緩存,你只需要在SQL 映射文件中加入簡(jiǎn)單的一行:<cache/>

這句簡(jiǎn)單的語(yǔ)句的作用如下:

1. 所有在映射文件里的select 語(yǔ)句都將被緩存。
2. 所有在映射文件里insert,update 和delete 語(yǔ)句會(huì)清空緩存。
3. 緩存使用“最近很少使用”算法來(lái)回收
4. 緩存不會(huì)被設(shè)定的時(shí)間所清空。
5. 每個(gè)緩存可以存儲(chǔ)1024 個(gè)列表或?qū)ο蟮囊茫ú还懿樵?xún)出來(lái)的結(jié)果是什么)。
6. 緩存將作為“讀/寫(xiě)”緩存,意味著獲取的對(duì)象不是共享的且對(duì)調(diào)用者是安全的。不會(huì)有其它的調(diào)用
7. 者或線程潛在修改。

例如,創(chuàng)建一個(gè)FIFO 緩存讓60 秒就清空一次,存儲(chǔ)512 個(gè)對(duì)象結(jié)果或列表引用,并且返回的結(jié)果是只讀。因?yàn)樵诓挥玫木€程里的兩個(gè)調(diào)用者修改它們可能會(huì)導(dǎo)致引用沖突。

<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"> 
</cache> 

還可以在不同的命名空間里共享同一個(gè)緩存配置或者實(shí)例。在這種情況下,你就可以使用cache-ref 來(lái)引用另外一個(gè)緩存。

<cache-ref namespace="com.liming.manager.data.StudentMapper"/> 

Cache 語(yǔ)句屬性配置細(xì)節(jié):

屬性
說(shuō)明
取值
默認(rèn)值
eviction
緩存策略:
LRU - 最近最少使用法:移出最近較長(zhǎng)周期內(nèi)都沒(méi)有被使用的對(duì)象。
FIFI- 先進(jìn)先出:移出隊(duì)列里較早的對(duì)象
SOFT - 軟引用:基于軟引用規(guī)則,使用垃圾回收機(jī)制來(lái)移出對(duì)象
WEAK - 弱引用:基于弱引用規(guī)則,使用垃圾回收機(jī)制來(lái)強(qiáng)制性地移出對(duì)象
LRU
FIFI
SOFT
WEAK
LRU
flushInterval
代表一個(gè)合理的毫秒總計(jì)時(shí)間。默認(rèn)是不設(shè)置,因此使用無(wú)間隔清空即只能調(diào)用語(yǔ)句來(lái)清空。
正整數(shù)
不設(shè)置
size
緩存的對(duì)象的大小
正整數(shù)
1024
readOnly
只讀緩存將對(duì)所有調(diào)用者返回同一個(gè)實(shí)例。因此都不能被修改,這可以極大的提高性能??蓪?xiě)的緩存將通過(guò)序列
化來(lái)返回一個(gè)緩存對(duì)象的拷貝。這會(huì)比較慢,但是比較安全。所以默認(rèn)值是false。
true|false
false

相關(guān)文章

  • Java 創(chuàng)建URL的常見(jiàn)問(wèn)題及解決方案

    Java 創(chuàng)建URL的常見(jiàn)問(wèn)題及解決方案

    這篇文章主要介紹了Java 創(chuàng)建URL的常見(jiàn)問(wèn)題及解決方案的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • java設(shè)計(jì)模式-組合模式詳解

    java設(shè)計(jì)模式-組合模式詳解

    這篇文章主要介紹了JAVA設(shè)計(jì)模式之組合模式,簡(jiǎn)單說(shuō)明了組合模式的原理,并結(jié)合實(shí)例分析了java組合模式的具體用法,需要的朋友可以參考下
    2021-07-07
  • springboot添加https服務(wù)器的方法

    springboot添加https服務(wù)器的方法

    這篇文章主要介紹了springboot添加https服務(wù)器的方法,小編在android開(kāi)發(fā)中發(fā)現(xiàn)很多app都是https訪問(wèn)的,為了方便測(cè)試,自己搭建了一個(gè)https服務(wù)器,需要的朋友可以參考下
    2017-11-11
  • Spring Cloud Gateway實(shí)現(xiàn)灰度發(fā)布方案

    Spring Cloud Gateway實(shí)現(xiàn)灰度發(fā)布方案

    灰度發(fā)布是在微服務(wù)中的表現(xiàn)為同一服務(wù)同時(shí)上線不同版本,讓一部分用戶(hù)使用新版本來(lái)驗(yàn)證新特性,如果驗(yàn)證沒(méi)有問(wèn)題,則將所有用戶(hù)都遷移到新版本上,本文就來(lái)介紹一下如何實(shí)現(xiàn),感興趣的可以了解一下
    2023-12-12
  • js判斷是否含有GBK以外的字符的函數(shù)

    js判斷是否含有GBK以外的字符的函數(shù)

    判斷是否含有GBK以外的特殊字符
    2008-10-10
  • SpringBoot整合RabbitMQ實(shí)現(xiàn)延遲隊(duì)列和死信隊(duì)列

    SpringBoot整合RabbitMQ實(shí)現(xiàn)延遲隊(duì)列和死信隊(duì)列

    RabbitMQ的死信隊(duì)列用于接收其他隊(duì)列中的“死信”消息,所謂“死信”,是指滿足一定條件而無(wú)法被消費(fèi)者正確處理的消息,死信隊(duì)列通常與RabbitMQ的延遲隊(duì)列一起使用,本文給大家介紹了SpringBoot整合RabbitMQ實(shí)現(xiàn)延遲隊(duì)列和死信隊(duì)列,需要的朋友可以參考下
    2024-06-06
  • MyBatis 動(dòng)態(tài)SQL和緩存機(jī)制實(shí)例詳解

    MyBatis 動(dòng)態(tài)SQL和緩存機(jī)制實(shí)例詳解

    這篇文章主要介紹了MyBatis 動(dòng)態(tài)SQL和緩存機(jī)制實(shí)例詳解,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-09-09
  • SpringBoot中到底該如何解決跨域問(wèn)題

    SpringBoot中到底該如何解決跨域問(wèn)題

    跨域問(wèn)題更是老生常談,隨便用標(biāo)題去google或百度一下,能搜出一大片解決方案,這篇文章主要給大家介紹了關(guān)于SpringBoot中到底該如何解決跨域問(wèn)題的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • java?io文件操作從文件讀取數(shù)據(jù)的六種方法

    java?io文件操作從文件讀取數(shù)據(jù)的六種方法

    這篇文章主要為大家介紹了java?io操作總結(jié)從文件讀取數(shù)據(jù)的六種方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-03-03
  • java學(xué)習(xí)教程之常量折疊詳解

    java學(xué)習(xí)教程之常量折疊詳解

    這篇文章主要給大家介紹了關(guān)于java學(xué)習(xí)教程之常量折疊的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-09-09

最新評(píng)論