轉:ibatis常用16條SQL語句

来源:http://www.cnblogs.com/huiy/archive/2016/10/26/6000676.html
-Advertisement-
Play Games

1.輸入參數為單個值 delete from MemberAccessLog where accessTimestamp = #value# delete from MemberAccessLog where accessTimestamp = #value# 2.輸入參數為一個對象 ... ...


1.輸入參數為單個值

<delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore"    
 parameterClass="long">    
 delete from    
 MemberAccessLog    
 where    
 accessTimestamp = #value#    
 </delete>   

 <delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore"   
 parameterClass="long">   
 delete from   
 MemberAccessLog   
 where   
 accessTimestamp = #value#   
 </delete>

2.輸入參數為一個對象

<insert id="com.fashionfree.stat.accesslog.MemberAccessLog.insert"    
 parameterClass="com.fashionfree.stat.accesslog.model.MemberAccessLog>    
 insert into MemberAccessLog    
 (    
 accessLogId, memberId, clientIP,    
 httpMethod, actionId, requestURL,    
 accessTimestamp, extend1, extend2,    
 extend3    
 )    
 values    
 (    
 #accessLogId#, #memberId#,    
 #clientIP#, #httpMethod#,    
 #actionId#, #requestURL#,    
 #accessTimestamp#, #extend1#,    
 #extend2#, #extend3#    
 )    
 </insert>   

 <insert id="com.fashionfree.stat.accesslog.MemberAccessLog.insert"   
 parameterClass="com.fashionfree.stat.accesslog.model.MemberAccessLog>   
 insert into MemberAccessLog   
 (   
 accessLogId, memberId, clientIP,   
 httpMethod, actionId, requestURL,   
 accessTimestamp, extend1, extend2,   
 extend3   
 )   
 values   
 (   
 #accessLogId#, #memberId#,   
 #clientIP#, #httpMethod#,   
 #actionId#, #requestURL#,   
 #accessTimestamp#, #extend1#,   
 #extend2#, #extend3#   
 )   
 </insert

3.輸入參數為一個java.util.HashMap

<select id="com.fashionfree.stat.accesslog.selectActionIdAndActionNumber"    
 parameterClass="hashMap"    
 resultMap="getActionIdAndActionNumber">    
 select    
 actionId, count(*) as count    
 from    
 MemberAccessLog    
 where    
 memberId = #memberId#    
 and accessTimestamp &gt; #start#    
 and accessTimestamp &lt;= #end#    
 group by actionId    
 </select>
<select id="com.fashionfree.stat.accesslog.selectActionIdAndActionNumber"   
 parameterClass="hashMap"   
 resultMap="getActionIdAndActionNumber">   
 select   
 actionId, count(*) as count   
 from   
 MemberAccessLog   
 where   
 memberId = #memberId#   
 and accessTimestamp &gt; #start#   
 and accessTimestamp &lt;= #end#   
 group by actionId   
 </select>

4.輸入參數中含有數組

<insert id="updateStatusBatch" parameterClass="hashMap">    
 update    
 Question    
 set    
 status = #status#    
 <dynamic prepend="where questionId in">    
 <isNotNull property="actionIds">    
 <iterate property="actionIds" open="(" close=")" conjunction=",">    
 #actionIds[]#    
 </iterate>    
 </isNotNull>    
 </dynamic>    
 </insert>   

 <insert id="updateStatusBatch" parameterClass="hashMap">   
 update   
 Question   
 set   
 status = #status#   
 <dynamic prepend="where questionId in">   
 <isNotNull property="actionIds">   
 <iterate property="actionIds" open="(" close=")" conjunction=",">   
 #actionIds[]#   
 </iterate>   
 </isNotNull>   
 </dynamic>   
 </insert>   

說明:actionIds為傳入的數組的名字; 使用dynamic標簽避免數組為空時導致sql語句語法出錯; 使用isNotNull標簽避免數組為null時ibatis解析出錯

5.傳遞參數只含有一個數組

<select id="com.fashionfree.stat.accesslog.model.StatMemberAction.selectActionIdsOfModule"    
 resultClass="hashMap">    
 select    
 moduleId, actionId    
 from    
 StatMemberAction    
 <dynamic prepend="where moduleId in">    
 <iterate open="(" close=")" conjunction=",">    
 #[]#    
 </iterate>    
 </dynamic>    
 order by    
 moduleId    
 </select>

 <select id="com.fashionfree.stat.accesslog.model.StatMemberAction.selectActionIdsOfModule"   
 resultClass="hashMap">   
 select   
 moduleId, actionId   
 from   
 StatMemberAction   
 <dynamic prepend="where moduleId in">   
 <iterate open="(" close=")" conjunction=",">   
 #[]#   
 </iterate>   
 </dynamic>   
 order by   
 moduleId   
 </select>   

說明:註意select的標簽中沒有parameterClass一項

另:這裡也可以把數組放進一個hashMap中,但增加額外開銷,不建議使用

6.讓ibatis把參數直接解析成字元串

<select id="com.fashionfree.stat.accesslog.selectSumDistinctCountOfAccessMemberNum"    
 parameterClass="hashMap" resultClass="int">    
 select    
 count(distinct memberId)    
 from    
 MemberAccessLog    
 where    
 accessTimestamp &gt;= #start#    
 and accessTimestamp &lt; #end#    
 and actionId in $actionIdString$    
 </select>  

 <select id="com.fashionfree.stat.accesslog.selectSumDistinctCountOfAccessMemberNum"   
 parameterClass="hashMap" resultClass="int">   
 select   
 count(distinct memberId)   
 from   
 MemberAccessLog   
 where   
 accessTimestamp &gt;= #start#   
 and accessTimestamp &lt; #end#   
 and actionId in $actionIdString$   
 </select>  

說明:使用這種方法存在sql註入的風險,不推薦使用

7.分頁查詢 (pagedQuery)

<select id="com.fashionfree.stat.accesslog.selectMemberAccessLogBy"    
 parameterClass="hashMap" resultMap="MemberAccessLogMap">    
 <include refid="selectAllSql"/>    
 <include refid="whereSql"/>    
 <include refid="pageSql"/>    
 </select>    
 <select id="com.fashionfree.stat.accesslog.selectMemberAccessLogBy.Count"    
 parameterClass="hashMap" resultClass="int">    
 <include refid="countSql"/>    
 <include refid="whereSql"/>    
 </select>    
 <sql id="selectAllSql">    
 select    
 accessLogId, memberId, clientIP,    
 httpMethod, actionId, requestURL,    
 accessTimestamp, extend1, extend2,    
 extend3    
 from    
 MemberAccessLog    
 </sql>    
 <sql id="whereSql">    
 accessTimestamp &lt;= #accessTimestamp#    
 </sql>    
 <sql id="countSql">    
 select    
 count(*)    
 from    
 MemberAccessLog    
 </sql>    
 <sql id="pageSql">    
 <dynamic>    
 <isNotNull property="startIndex">    
 <isNotNull property="pageSize">    
 limit #startIndex# , #pageSize#    
 </isNotNull>    
 </isNotNull>    
 </dynamic>    
 </sql>

 <select id="com.fashionfree.stat.accesslog.selectMemberAccessLogBy"   
 parameterClass="hashMap" resultMap="MemberAccessLogMap">   
 <include refid="selectAllSql"/>   
 <include refid="whereSql"/>   
 <include refid="pageSql"/>   
 </select>   
 <select id="com.fashionfree.stat.accesslog.selectMemberAccessLogBy.Count"   
 parameterClass="hashMap" resultClass="int">   
 <include refid="countSql"/>   
 <include refid="whereSql"/>   
 </select>   
 <sql id="selectAllSql">   
 select   
 accessLogId, memberId, clientIP,   
 httpMethod, actionId, requestURL,   
 accessTimestamp, extend1, extend2,   
 extend3   
 from   
 MemberAccessLog   
 </sql>   
 <sql id="whereSql">   
 accessTimestamp &lt;= #accessTimestamp#   
 </sql>   
 <sql id="countSql">   
 select   
 count(*)   
 from   
 MemberAccessLog   
 </sql>   
 <sql id="pageSql">   
 <dynamic>   
 <isNotNull property="startIndex">   
 <isNotNull property="pageSize">   
 limit #startIndex# , #pageSize#   
 </isNotNull>   
 </isNotNull>   
 </dynamic>   
 </sql>   

說明:本例中,代碼應為:

    HashMap hashMap = new HashMap(); 
    hashMap.put(“accessTimestamp”, someValue); 
    pagedQuery(“com.fashionfree.stat.accesslog.selectMemberAccessLogBy”, hashMap); 

pagedQuery方法首先去查找名為com.fashionfree.stat.accesslog.selectMemberAccessLogBy.Count 的mapped statement來進行sql查詢,從而得到com.fashionfree.stat.accesslog.selectMemberAccessLogBy查詢的記錄個數, 再進行所需的paged sql查詢(com.fashionfree.stat.accesslog.selectMemberAccessLogBy),具體過程參見utils類中的相關代碼

8.sql語句中含有大於號>、小於號< 1. 將大於號、小於號寫為: &gt; &lt; 如:

<delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">    
 delete from    
 MemberAccessLog    
 where    
 accessTimestamp &lt;= #value#    
 </delete>   
 Xml代碼  
 <delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">   
 delete from   
 MemberAccessLog   
 where   
 accessTimestamp &lt;= #value#   
 </delete>   

    將特殊字元放在xml的CDATA區內:

 <delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">    
 <![CDATA[   
 delete from   
 MemberAccessLog   
 where   
 accessTimestamp <= #value#   
 ]]>    
 </delete>   

 <delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">   
 <![CDATA[  
 delete from  
 MemberAccessLog  
 where  
 accessTimestamp <= #value#  
 ]]>   
 </delete>   

推薦使用第一種方式,寫為&lt;&gt; (XML不對CDATA里的內容進行解析,因此如果CDATA中含有dynamic標簽,將不起作用)

9.include和sql標簽 將常用的sql語句整理在一起,便於共用:

<sql id="selectBasicSql">    
 select    
 samplingTimestamp,onlineNum,year,    
 month,week,day,hour    
 from    
 OnlineMemberNum    
 </sql>    
 <sql id="whereSqlBefore">    
 where samplingTimestamp &lt;= #samplingTimestamp#    
 </sql>    
 <select id="com.fashionfree.accesslog.selectOnlineMemberNumsBeforeSamplingTimestamp" parameterClass="hashmap" resultClass="OnlineMemberNum">    
 <include refid="selectBasicSql" />    
 <include refid="whereSqlBefore" />    
 </select>   

 <sql id="selectBasicSql">   
 select   
 samplingTimestamp,onlineNum,year,   
 month,week,day,hour   
 from   
 OnlineMemberNum   
 </sql>   
 <sql id="whereSqlBefore">   
 where samplingTimestamp &lt;= #samplingTimestamp#   
 </sql>   
 <select id="com.fashionfree.accesslog.selectOnlineMemberNumsBeforeSamplingTimestamp" parameterClass="hashmap" resultClass="OnlineMemberNum">   
 <include refid="selectBasicSql" />   
 <include refid="whereSqlBefore" />   
 </select>   

註意:sql標簽只能用於被引用,不能當作mapped statement。如上例中有名為selectBasicSql的sql元素,試圖使用其作為sql語句執行是錯誤的:

sqlMapClient.queryForList(“selectBasicSql”); ×

10.隨機選取記錄

<sql id=”randomSql”>   
 ORDER BY rand() LIMIT #number#   
 </sql>
從資料庫中隨機選取number條記錄(只適用於MySQL)

11.將SQL GROUP BY分組中的欄位拼接

<sql id=”selectGroupBy>    
 SELECT    
 a.answererCategoryId, a.answererId, a.answererName,    
 a.questionCategoryId, a.score, a.answeredNum,    
 a.correctNum, a.answerSeconds, a.createdTimestamp,    
 a.lastQuestionApprovedTimestamp, a.lastModified, GROUP_CONCAT(q.categoryName) as categoryName    
 FROM    
 AnswererCategory a, QuestionCategory q    
 WHERE a.questionCategoryId = q.questionCategoryId    
 GROUP BY a.answererId    
 ORDER BY a.answererCategoryId    
 </sql>

 <sql id=”selectGroupBy>   
 SELECT   
 a.answererCategoryId, a.answererId, a.answererName,   
 a.questionCategoryId, a.score, a.answeredNum,   
 a.correctNum, a.answerSeconds, a.createdTimestamp,   
 a.lastQuestionApprovedTimestamp, a.lastModified, GROUP_CONCAT(q.categoryName) as categoryName   
 FROM   
 AnswererCategory a, QuestionCategory q   
 WHERE a.questionCategoryId = q.questionCategoryId   
 GROUP BY a.answererId   
 ORDER BY a.answererCategoryId   
 </sql>  

註:SQL中使用了MySQL的GROUP_CONCAT函數

12.按照IN裡面的順序進行排序

①MySQL:

 <sql id=”groupByInArea”>    
 select    
 moduleId, moduleName,    
 status, lastModifierId, lastModifiedName,    
 lastModified    
 from    
 StatModule    
 where    
 moduleId in (3, 5, 1)    
 order by    
 instr(',3,5,1,' , ','+ltrim(moduleId)+',')    
 </sql>   

 <sql id=”groupByInArea”>   
 select   
 moduleId, moduleName,   
 status, lastModifierId, lastModifiedName,   
 lastModified   
 from   
 StatModule   
 where   
 moduleId in (3, 5, 1)   
 order by   
 instr(',3,5,1,' , ','+ltrim(moduleId)+',')   
 </sql>   

②SQLSERVER:

 <sql id=”groupByInArea”>    
 select    
 moduleId, moduleName,    
 status, lastModifierId, lastModifiedName,    
 lastModified    
 from    
 StatModule    
 where    
 moduleId in (3, 5, 1)    
 order by    
 charindex(','+ltrim(moduleId)+',' , ',3,5,1,')    
 </sql>  

 <sql id=”groupByInArea”>   
 select   
 moduleId, moduleName,   
 status, lastModifierId, lastModifiedName,   
 lastModified   
 from   
 StatModule   
 where   
 moduleId in (3, 5, 1)   
 order by   
 charindex(','+ltrim(moduleId)+',' , ',3,5,1,')   
 </sql>

說明:查詢結果將按照moduleId在in列表中的順序(3, 5, 1)來返回

MySQL : instr(str, substr)

SQLSERVER: charindex(substr, str) 返回字元串str 中子字元串的第一個出現位置 ltrim(str) 返回字元串str, 其引導(左面的)空格字元被刪除

13.resultMap resultMap負責將SQL查詢結果集的列值映射成Java Bean的屬性值

<resultMap class="java.util.HashMap" id="getActionIdAndActionNumber">    
 <result column="actionId" property="actionId" jdbcType="BIGINT" javaType="long"/>    
 <result column="count" property="count" jdbcType="INT" javaType="int"/>    
 </resultMap>   
 Xml代碼  
 <resultMap class="java.util.HashMap" id="getActionIdAndActionNumber">   
 <result column="actionId" property="actionId" jdbcType="BIGINT" javaType="long"/>   
 <result column="count" property="count" jdbcType="INT" javaType="int"/>   
 </resultMap>   

使用resultMap稱為顯式結果映射,與之對應的是resultClass(內聯結果映射),使用resultClass的最大好處便是簡單、方便,不需顯示指定結果,
由iBATIS根據反射來確定自行決定。而resultMap則可以通過指定jdbcType和javaType,提供更嚴格的配置認證。

14.typeAlias

<typeAlias alias="MemberOnlineDuration" type="com.fashionfree.stat.accesslog.model.MemberOnlineDuration" />    
 <typeAlias>

允許你定義別名,避免重覆輸入過長的名字

15.remap

<select id="testForRemap" parameterClass="hashMap" resultClass="hashMap" remapResults="true">    
 select    
 userId    
 <isEqual property="tag" compareValue="1">    
 , userName    
 </isEqual>    
 <isEqual property="tag" compareValue="2">    
 , userPassword    
 </isEqual>    
 from    
 UserInfo    
 </select>   

 <select id="testForRemap" parameterClass="hashMap" resultClass="hashMap" remapResults="true">   
 select   
 userId   
 <isEqual property="tag" compareValue="1">   
 , userName   
 </isEqual>   
 <isEqual property="tag" compareValue="2">   
 , userPassword   
 </isEqual>   
 from   
 UserInfo   
 </select>   

此例中,根據參數tag值的不同,會獲得不同的結果集,如果沒有remapResults="true"屬性,iBatis會將第一次查詢時的結果集緩存,下次再執行時(必須還是該進程中)不會再執行結果集映射,而是會使用緩存的結果集。

因此,如果上面的例子中remapResult為預設的false屬性,而有一段程式這樣書寫:

 HashMap<String, Integer> hashMap = new HashMap<String, Integer>();    
 hashMap.put("tag", 1);    
 sqlClient.queryForList("testForRemap", hashMap);    
 hashMap.put("tag", 2);    
 sqlClient.queryForList("testForRemap", hashMap);   
 Java代碼  
 HashMap<String, Integer> hashMap = new HashMap<String, Integer>();   
 hashMap.put("tag", 1);   
 sqlClient.queryForList("testForRemap", hashMap);   
 hashMap.put("tag", 2);   
 sqlClient.queryForList("testForRemap", hashMap);   

則程式會在執行最後一句的query查詢時報錯,原因就是iBATIS使用了第一次查詢時的結果集,而前後兩次的結果集是不同的:(userId, userName)和(userId, userPassword),所以導致出錯。如果使用了remapResults="true"這一屬性,iBATIS會在每次執行查詢時都執行結果集映射,從而避免錯誤的發生(此時會有較大的開銷)。

16.dynamic標簽的prepend dynamic標簽的prepend屬性作為首碼添加到結果內容前面,當標簽的結果內容為空時,prepend屬性將不起作用

當dynamic標簽中存在prepend屬性時,將會把其嵌套子標簽的第一個prepend屬性忽略。例如:

 <sql id="whereSql">    
 <dynamic prepend="where ">    
 <isNotNull property="userId" prepend="BOGUS">    
 userId = #userId#    
 </isNotNull>    
 <isNotEmpty property="userName" prepend="and ">    
 userName = #userName#    
 </isNotEmpty>    
 </dynamic>    
 </sql>  

 <sql id="whereSql">   
 <dynamic prepend="where ">   
 <isNotNull property="userId" prepend="BOGUS">   
 userId = #userId#   
 </isNotNull>   
 <isNotEmpty property="userName" prepend="and ">   
 userName = #userName#   
 </isNotEmpty>   
 </dynamic>   
 </sql>  

此例中,dynamic標簽中含有兩個子標簽<isNotNull><isNotEmpty>。根據前面敘述的原則,如果<isNotNull>標簽中沒有prepend="BOGUS" 這一假的屬性來讓dynamic去掉的話,<isNotEmpty>標簽中的and就會被忽略,會造成sql語法錯誤。

註意:當dynamic標簽沒有prepend屬性時,不會自動忽略其子標簽的第一個prepend屬性。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近在苦於思考kmeans演算法的MPI並行化,花了兩天的時間先把串列版本實現了。 聚類問題就是給定一個元素集合V,其中每個元素具有d個可觀察屬性,使用某種演算法將V劃分成k個子集,要求每個子集內部的元素之間相異度儘可能低,而不同子集的元素相異度儘可能高。 下麵是google到該演算法的一個流程圖,表意清 ...
  • 通過打電話的例子講解TCP的三次握手和四次揮手,通俗易懂,容易理解 ...
  • 前言 首先是例行的國際慣例,本文寫於本人學習設計模式的路上,適合同樣學習設計模式的朋友交流使用,大神誤入請留下您寶貴的意見,先行謝過; 前面我們已經學習過 簡單工廠模式 ,今天來學習第二個工廠模式 方法工廠模式 。 定義 百度百科 工廠方法模式的意義是定義一個創建產品對象的工廠介面,將實際創建工作推 ...
  • 英文文檔: class float([x]) Return a floating point number constructed from a number or string x. If the argument is a string, it should contain a decimal ...
  • 筆者最近入手ThinkPHP5,準備用它來實現一個學生作業管理系統。簡單的說就是學生在上面交老師佈置的課程作業,老師也可以發佈修改作業。過程中勢必會碰到學生、班級和老師之間的關係。它們之間的關係是多對多的關係。下麵我們主要分析班級和作業的關係。每個班級的學生可以有多個作業,同樣的作業也可以佈置給不同 ...
  • 簡單來說: .h的是標準C的頭文件,沒有.h的是標準C++的頭文件,兩種都是頭文件。 造成這兩種形式不同的原因,是C++的發展歷史決定的,剛纔正好有別的人也問這個問題,這裡我再回答一下(註意vs2008和vs2005對標準C++的支持是一樣的): 1、以iostream和stdio.h為例,iost ...
  • 英文文檔: filter(function, iterable) Construct an iterator from those elements of iterable for which function returns true. iterable may be either a seque ...
  • 1、用戶發送請求到前端控制器(DispatcherServlet); 2、前端控制器轉發請求到處理器映射器(HandlerMapping); 3、處理器映射器將攔截的Action返回到前端控制器; 4、前端控制器將攔截的Action請求處理器適配器(HandlerAdapter); 5、處理器適配器 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...