主頁 > 移動端開發 > Mysql系列第十七講 流程控制陳述句(高手進階)

Mysql系列第十七講 流程控制陳述句(高手進階)

2020-09-30 22:15:10 移動端開發

Mysql系列第十七講

  • 準備資料
  • if函式
  • CASE結構
    • 第1種用法
    • 第2種用法
  • if結構
  • 回圈
  • while回圈
  • repeat回圈
  • loop回圈

準備資料

/*建庫javacode2018*/
drop database if exists javacode2018;
create database javacode2018;

/*切換到javacode2018庫*/
use javacode2018;

/*創建表:t_user*/
DROP TABLE IF EXISTS t_user;
CREATE TABLE t_user(
  id int PRIMARY KEY COMMENT '編號',
  sex TINYINT not null DEFAULT 1 COMMENT '性別,1:男,2:女',
  name VARCHAR(16) not NULL DEFAULT '' COMMENT '姓名'
)COMMENT '用戶表';

/*插入資料*/
INSERT INTO t_user VALUES
(1,1,'路人甲Java'),(2,1,'張學友'),(3,2,'王祖賢'),(4,1,'郭富城'),(5,2,'李嘉欣');

SELECT * FROM t_user;

DROP TABLE IF EXISTS test1;
CREATE TABLE test1 (a int not null);

DROP TABLE IF EXISTS test2;
CREATE TABLE test2 (a int not null,b int NOT NULL );

if函式

語法

if(條件運算式,1,2);

if函式有3個引數,

當引數1為true的時候,回傳值1,否則回傳值2,

示例
需求:查詢t_user表資料,回傳:編號、性別(男、女)、姓名,

分析一下:資料庫中性別用數字表示的,我們需要將其轉換為(男、女),可以使用if函式,

mysql> SELECT id 編號,if(sex=1,'男','女') 性別,name 姓名 FROM t_user;
+--------+--------+---------------+
| 編號   | 性別   | 姓名          |
+--------+--------+---------------+
|      1 || 路人甲Java    |
|      2 || 張學友        |
|      3 || 王祖賢        |
|      4 || 郭富城        |
|      5 || 李嘉欣        |
+--------+--------+---------------+
5 rows in set (0.00 sec)

CASE結構

第1種用法

類似于java中的switch陳述句,

case 運算式
when1 then 結果1或者陳述句1(如果是陳述句需要加分號)
when2 then 結果2或者陳述句2
...
else 結果n或者陳述句n
end [case] (如果是放在begin end之間需要加case,如果在select后則不需要)

示例1:select中使用

查詢t_user表資料,回傳:編號、性別(男、女)、姓名,

/*寫法1:類似于java中的if else*/
SELECT id 編號,(CASE sex WHEN 1 THEN '男' ELSE '女' END) 性別,name 姓名 FROM t_user;
/*寫法2:類似于java中的if else if*/
SELECT id 編號,(CASE sex WHEN 1 then '男' WHEN 2 then '女' END) 性別,name 姓名 FROM t_user;

示例2:begin end中使用

寫一個存盤程序,接受3個引數:id,性別(男、女),姓名,然后插入到t_user表

創建存盤程序:

/*洗掉存盤程序proc1*/
DROP PROCEDURE IF EXISTS proc1;
/*s洗掉id=6的記錄*/
DELETE FROM t_user WHERE id=6;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序proc1*/
CREATE PROCEDURE proc1(id int,sex_str varchar(8),name varchar(16))
  BEGIN
    /*宣告變數v_sex用于存放性別*/
    DECLARE v_sex TINYINT UNSIGNED;
    /*根據sex_str的值來設定性別*/
    CASE sex_str
      when '男' THEN
      SET v_sex = 1;
    WHEN '女' THEN
      SET v_sex = 2;
    END CASE ;
    /*插入資料*/
    INSERT INTO t_user VALUES (id,v_sex,name);
  END $
/*結束符置為;*/
DELIMITER ;

呼叫存盤程序:

CALL proc1(6,'男','郭富城');

查看效果:

mysql> select * from t_user;
+----+-----+---------------+
| id | sex | name          |
+----+-----+---------------+
|  1 |   1 | 路人甲Java    |
|  2 |   1 | 張學友        |
|  3 |   2 | 王祖賢        |
|  4 |   1 | 郭富城        |
|  5 |   2 | 李嘉欣        |
|  6 |   1 | 郭富城        |
+----+-----+---------------+
6 rows in set (0.00 sec)

示例3:函式中使用

需求:寫一個函式,根據t_user表sex的值,回傳男女

創建函式:

/*洗掉存盤程序proc1*/
DROP FUNCTION IF EXISTS fun1;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序proc1*/
CREATE FUNCTION fun1(sex TINYINT UNSIGNED)
  RETURNS varchar(8)
  BEGIN
    /*宣告變數v_sex用于存放性別*/
    DECLARE v_sex VARCHAR(8);
    CASE sex
    WHEN 1 THEN
      SET v_sex:='男';
    ELSE
      SET v_sex:='女';
    END CASE;
    RETURN v_sex;
  END $
/*結束符置為;*/
DELIMITER ;

看一下效果:

mysql> select sex, fun1(sex) 性別,name FROM t_user;
+-----+--------+---------------+
| sex | 性別   | name          |
+-----+--------+---------------+
|   1 || 路人甲Java    |
|   1 || 張學友        |
|   2 || 王祖賢        |
|   1 || 郭富城        |
|   2 || 李嘉欣        |
|   1 || 郭富城        |
+-----+--------+---------------+
6 rows in set (0.00 sec)

第2種用法

類似于java中多重if陳述句,

case
when 條件1 then 結果1或者陳述句1(如果是陳述句需要加分號)
when 條件2 then 結果2或者陳述句2
...
else 結果n或者陳述句n
end [case] (如果是放在begin end之間需要加case,如果是在select后面case可以省略)

if結構

if結構類似于java中的 if…else if…else的語法,如下:

if結構類似于java中的 if..else ifelse的語法,如下:

if 條件陳述句1 then 陳述句1;
elseif 條件陳述句2 then 陳述句2;
...
else 陳述句n;
end if;

只能使用在begin end之間,

示例

寫一個存盤程序,實作用戶資料的插入和新增,如果id存在,則修改,不存在則新增,并回傳結果

/*洗掉id=7的記錄*/
DELETE FROM t_user WHERE id=7;
/*洗掉存盤程序*/
DROP PROCEDURE IF EXISTS proc2;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序*/
CREATE PROCEDURE proc2(v_id int,v_sex varchar(8),v_name varchar(16),OUT result TINYINT)
  BEGIN
    DECLARE v_count TINYINT DEFAULT 0;/*用來保存user記錄的數量*/
    /*根據v_id查詢資料放入v_count中*/
    select count(id) into v_count from t_user where id = v_id;
    /*v_count>0表示資料存在,則修改,否則新增*/
    if v_count>0 THEN
      BEGIN
        DECLARE lsex TINYINT;
        select if(lsex='男',1,2) into lsex;
        update t_user set sex = lsex,name = v_name where id = v_id;
        /*獲取update影響行數*/
        select ROW_COUNT() INTO result;
      END;
    else
      BEGIN
        DECLARE lsex TINYINT;
        select if(lsex='男',1,2) into lsex;
        insert into t_user VALUES (v_id,lsex,v_name);
        select 0 into result;
      END;
    END IF;
  END $
/*結束符置為;*/
DELIMITER ;

看效果:

mysql> SELECT * FROM t_user;
+----+-----+---------------+
| id | sex | name          |
+----+-----+---------------+
|  1 |   1 | 路人甲Java    |
|  2 |   1 | 張學友        |
|  3 |   2 | 王祖賢        |
|  4 |   1 | 郭富城        |
|  5 |   2 | 李嘉欣        |
|  6 |   1 | 郭富城        |
+----+-----+---------------+
6 rows in set (0.00 sec)

mysql> CALL proc2(7,'男','黎明',@result);
Query OK, 1 row affected (0.00 sec)

mysql> SELECT @result;
+---------+
| @result |
+---------+
|       0 |
+---------+
1 row in set (0.00 sec)

mysql> SELECT * FROM t_user;
+----+-----+---------------+
| id | sex | name          |
+----+-----+---------------+
|  1 |   1 | 路人甲Java    |
|  2 |   1 | 張學友        |
|  3 |   2 | 王祖賢        |
|  4 |   1 | 郭富城        |
|  5 |   2 | 李嘉欣        |
|  6 |   1 | 郭富城        |
|  7 |   2 | 黎明          |
+----+-----+---------------+
7 rows in set (0.00 sec)

mysql> CALL proc2(7,'男','梁朝偉',@result);
Query OK, 1 row affected (0.00 sec)

mysql> SELECT @result;
+---------+
| @result |
+---------+
|       1 |
+---------+
1 row in set (0.00 sec)

mysql> SELECT * FROM t_user;
+----+-----+---------------+
| id | sex | name          |
+----+-----+---------------+
|  1 |   1 | 路人甲Java    |
|  2 |   1 | 張學友        |
|  3 |   2 | 王祖賢        |
|  4 |   1 | 郭富城        |
|  5 |   2 | 李嘉欣        |
|  6 |   1 | 郭富城        |
|  7 |   2 | 梁朝偉        |
+----+-----+---------------+
7 rows in set (0.00 sec)

回圈

mysql中回圈有3種寫法

  1. while:類似于java中的while回圈

  2. repeat:類似于java中的do while回圈

  3. loop:類似于java中的while(true)死回圈,需要在內部進行控制,

回圈控制

對回圈內部的流程進行控制,如:

結束本次回圈

類似于java中的continue

iterate 回圈標簽;

退出回圈

類似于java中的break

leave 回圈標簽;

下面我們分別介紹3種回圈的使用,

while回圈

類似于java中的while回圈,

語法

[標簽:]while 回圈條件 do
回圈體
end while [標簽];

標簽:是給while取個名字,標簽和iterate、leave結合用于在回圈內部對回圈進行控制:如:跳出回圈、結束本次回圈,

注意:這個回圈先判斷條件,條件成立之后,才會執行回圈體,每次執行都會先進行判斷,

示例1:無回圈控制陳述句

根據傳入的引數v_count向test1表插入指定數量的資料,

/*洗掉test1表記錄*/
DELETE FROM test1;
/*洗掉存盤程序*/
DROP PROCEDURE IF EXISTS proc3;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序*/
CREATE PROCEDURE proc3(v_count int)
  BEGIN
    DECLARE i int DEFAULT 1;
    a:WHILE i<=v_count DO
      INSERT into test1 values (i);
      SET i=i+1;
    END WHILE;
  END $
/*結束符置為;*/
DELIMITER ;

見效果:

mysql> CALL proc3(5);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test1;
+---+
| a |
+---+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
+---+
5 rows in set (0.00 sec)

示例2:添加leave控制陳述句

根據傳入的引數v_count向test1表插入指定數量的資料,當插入超過10條,結束,

/*洗掉存盤程序*/
DROP PROCEDURE IF EXISTS proc4;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序*/
CREATE PROCEDURE proc4(v_count int)
  BEGIN
    DECLARE i int DEFAULT 1;
    a:WHILE i<=v_count DO
      INSERT into test1 values (i);
      /*判斷i=10,離開回圈a*/
      IF i=10 THEN
        LEAVE a;
      END IF;

      SET i=i+1;
    END WHILE;
  END $
/*結束符置為;*/
DELIMITER ;

見效果:

mysql> DELETE FROM test1;
Query OK, 20 rows affected (0.00 sec)

mysql> CALL proc4(20);
Query OK, 1 row affected (0.02 sec)

mysql> SELECT * from test1;
+----+
| a  |
+----+
|  1 |
|  2 |
|  3 |
|  4 |
|  5 |
|  6 |
|  7 |
|  8 |
|  9 |
| 10 |
+----+
10 rows in set (0.00 sec)

示例3:添加iterate控制陳述句

根據傳入的引數v_count向test1表插入指定數量的資料,只插入偶數資料,

/*洗掉test1表記錄*/
DELETE FROM test1;
/*洗掉存盤程序*/
DROP PROCEDURE IF EXISTS proc5;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序*/
CREATE PROCEDURE proc5(v_count int)
  BEGIN
    DECLARE i int DEFAULT 0;
    a:WHILE i<=v_count DO
      SET i=i+1;
      /*如果i不為偶數,跳過本次回圈*/
      IF i%2!=0 THEN
        ITERATE a;
      END IF;
      /*插入資料*/
      INSERT into test1 values (i);
    END WHILE;
  END $
/*結束符置為;*/
DELIMITER ;

見效果:

mysql> DELETE FROM test1;
Query OK, 5 rows affected (0.00 sec)

mysql> CALL proc5(10);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test1;
+----+
| a  |
+----+
|  2 |
|  4 |
|  6 |
|  8 |
| 10 |
+----+
5 rows in set (0.00 sec)

示例4:嵌套回圈

test2表有2個欄位(a,b),寫一個存盤程序(2個引數:v_a_count,v_b_count),使用雙重回圈插入資料,資料條件:a的范圍[1,v_a_count]、b的范圍[1,v_b_count]所有偶數的組合,

/*洗掉存盤程序*/
DROP PROCEDURE IF EXISTS proc8;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序*/
CREATE PROCEDURE proc8(v_a_count int,v_b_count int)
  BEGIN
    DECLARE v_a int DEFAULT 0;
    DECLARE v_b int DEFAULT 0;

    a:WHILE v_a<=v_a_count DO
      SET v_a=v_a+1;
      SET v_b=0;

      b:WHILE v_b<=v_b_count DO

        SET v_b=v_b+1;
        IF v_a%2!=0 THEN
          ITERATE a;
        END IF;

        IF v_b%2!=0 THEN
          ITERATE b;
        END IF;

        INSERT INTO test2 VALUES (v_a,v_b);

      END WHILE b;

    END WHILE a;
  END $
/*結束符置為;*/
DELIMITER ;

代碼中故意將ITERATE a;放在內層回圈中,主要讓大家看一下效果,

見效果:

mysql> DELETE FROM test2;
Query OK, 6 rows affected (0.00 sec)

mysql> CALL proc8(4,6);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test2;
+---+---+
| a | b |
+---+---+
| 2 | 2 |
| 2 | 4 |
| 2 | 6 |
| 4 | 2 |
| 4 | 4 |
| 4 | 6 |
+---+---+
6 rows in set (0.00 sec)

repeat回圈

語法

[標簽:]repeat
回圈體;
until 結束回圈的條件 end repeat [標簽];

repeat回圈類似于java中的do…while回圈,不管如何,回圈都會先執行一次,然后再判斷結束回圈的條件,不滿足結束條件,回圈體繼續執行,這塊和while不同,while是先判斷條件是否成立再執行回圈體,

示例1:無回圈控制陳述句

根據傳入的引數v_count向test1表插入指定數量的資料,

/*洗掉存盤程序*/
DROP PROCEDURE IF EXISTS proc6;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序*/
CREATE PROCEDURE proc6(v_count int)
  BEGIN
    DECLARE i int DEFAULT 1;
    a:REPEAT
      INSERT into test1 values (i);
      SET i=i+1;
    UNTIL i>v_count END REPEAT;
  END $
/*結束符置為;*/
DELIMITER ;

見效果:

mysql> DELETE FROM test1;
Query OK, 1 row affected (0.00 sec)

mysql> CALL proc6(5);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test1;
+---+
| a |
+---+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
+---+
5 rows in set (0.00 sec)

loop回圈

語法

[標簽:]loop
回圈體;
end loop [標簽];

loop相當于一個死回圈,需要在回圈體中使用iterate或者leave來控制回圈的執行,

示例1:無回圈控制陳述句

根據傳入的引數v_count向test1表插入指定數量的資料,

/*洗掉存盤程序*/
DROP PROCEDURE IF EXISTS proc7;
/*宣告結束符為$*/
DELIMITER $
/*創建存盤程序*/
CREATE PROCEDURE proc7(v_count int)
  BEGIN
    DECLARE i int DEFAULT 0;
    a:LOOP
      SET i=i+1;
      /*當i>v_count的時候退出回圈*/
      IF i>v_count THEN
        LEAVE a;
      END IF;
      INSERT into test1 values (i);
    END LOOP a;
  END $
/*結束符置為;*/
DELIMITER ;

見效果:

mysql> DELETE FROM test1;
Query OK, 5 rows affected (0.00 sec)

mysql> CALL proc7(5);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test1;
+---+
| a |
+---+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
+---+
5 rows in set (0.00 sec)
易兮科技 Java
18級大連海事大學在校生
網路工程 & 國際經濟與貿易 雙學位
中山市易兮軟體開發有限公司創始人
易兮科技團隊負責人
Java語言愛好者

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/143388.html

標籤:其他

上一篇:《深入淺出SQL》問答錄

下一篇:資料庫系統原理 - - (2)關系資料庫

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【從零開始擼一個App】Dagger2

    Dagger2是一個IOC框架,一般用于Android平臺,第一次接觸的朋友,一定會被搞得暈頭轉向。它延續了Java平臺Spring框架代碼碎片化,注解滿天飛的傳統。嘗試將各處代碼片段串聯起來,理清思緒,真不是件容易的事。更不用說還有各版本細微的差別。 與Spring不同的是,Spring是通過反射 ......

    uj5u.com 2020-09-10 06:57:59 more
  • Flutter Weekly Issue 66

    新聞 Flutter 季度調研結果分享 教程 Flutter+FaaS一體化任務編排的思考與設計 詳解Dart中如何通過注解生成代碼 GitHub 用對了嗎?Flutter 團隊分享如何管理大型開源專案 插件 flutter-bubble-tab-indicator A Flutter librar ......

    uj5u.com 2020-09-10 06:58:52 more
  • Proguard 常用規則

    介紹 Proguard 入口,如何查看輸出,如何使用 keep 設定入口以及使用實體,如何配置壓縮,混淆,校驗等規則。

    ......

    uj5u.com 2020-09-10 06:59:00 more
  • Android 開發技術周報 Issue#292

    新聞 Android即將獲得類AirDrop功能:可向附近設備快速分享檔案 谷歌為安卓檔案管理應用引入可安全隱藏資料的Safe Folder功能 Android TV新主界面將顯示電影、電視節目和應用推薦內容 泄露的Android檔案暗示了傳說中的谷歌Pixel 5a與折疊屏新機 谷歌發布Andro ......

    uj5u.com 2020-09-10 07:00:37 more
  • AutoFitTextureView Error inflating class

    報錯: Binary XML file line #0: Binary XML file line #0: Error inflating class xxx.AutoFitTextureView 解決: <com.example.testy2.AutoFitTextureView android: ......

    uj5u.com 2020-09-10 07:00:41 more
  • 根據Uri,Cursor沒有獲取到對應的屬性

    Android: 背景:呼叫攝像頭,拍攝視頻,指定保存的地址,但是回傳的Cursor檔案,只有名稱和大小的屬性,沒有其他諸如時長,連ID屬性都沒有 使用 cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Video.Media.DURATIO ......

    uj5u.com 2020-09-10 07:00:44 more
  • Android連載29-持久化技術

    一、持久化技術 我們平時所使用的APP產生的資料,在記憶體中都是瞬時的,會隨著斷電、關機等丟失資料,因此android系統采用了持久化技術,用于存盤這些“瞬時”資料 持久化技術包括:檔案存盤、SharedPreference存盤以及資料庫存盤,還有更復雜的SD卡記憶體儲。 二、檔案存盤 最基本存盤方式, ......

    uj5u.com 2020-09-10 07:00:47 more
  • Android Camera2Video整合到自己專案里

    背景: Android專案里呼叫攝像頭拍攝視頻,原本使用的 MediaStore.ACTION_VIDEO_CAPTURE, 后來因專案需要,改成了camera2 1.Camera2Video 官方demo有點問題,下載后,不能直接整合到專案 問題1.多次拍攝視頻崩潰 問題2.雙擊record按鈕, ......

    uj5u.com 2020-09-10 07:00:50 more
  • Android 開發技術周報 Issue#293

    新聞 谷歌為Android TV開發者提供多種新功能 Android 11將自動填表功能整合到鍵盤輸入建議中 谷歌宣布Android Auto即將支持更多的導航和數字停車應用 谷歌Pixel 5只有XL版本 搭載驍龍765G且將比Pixel 4更便宜 [圖]Wear OS將迎來重磅更新:應用啟動時間 ......

    uj5u.com 2020-09-10 07:01:38 more
  • 海豚星空掃碼投屏 Android 接收端 SDK 集成 六步驟

    掃碼投屏,開放網路,獨占設備,不需要額外下載軟體,微信掃碼,發現設備。支持標準DLNA協議,支持倍速播放。視頻,音頻,圖片投屏。好點意思。還支持自定義基于 DLNA 擴展的操作動作。好像要收費,沒體驗。 這里簡單記錄一下集成程序。 一 跟目錄的build.gradle添加私有mevan倉庫 mave ......

    uj5u.com 2020-09-10 07:01:43 more
最新发布
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:40:31 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:40:11 more
  • 歡迎頁輪播影片

    如圖,引導開始,球從上落下,同時淡入文字,然后文字開始輪播,最后一頁時停止,點擊進入首頁。 在來看看效果圖。 重力球先不講,主要歡迎輪播簡單實作 首先新建一個類 TextTranslationXGuideView,用于影片展示 文本是類似的,最后會有個圖片箭頭影片,布局很簡單,就是一個 TextVi ......

    uj5u.com 2023-04-20 08:39:36 more
  • 【FAQ】關于華為推送服務因營銷訊息頻次管控導致服務通訊類訊息

    一. 問題描述 使用華為推送服務下發IM訊息時,下發訊息請求成功且code碼為80000000,但是手機總是收不到訊息; 在華為推送自助分析(Beta)平臺查看發現,訊息發送觸發了頻控。 二. 問題原因及背景 2023年1月05日起,華為推送服務對咨詢營銷類訊息做了單個設備每日推送數量上限管理,具體 ......

    uj5u.com 2023-04-20 08:39:13 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:16:23 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:16:15 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:15:46 more
  • iOS從UI記憶體地址到讀取成員變數(oc/swift)

    開發除錯時,我們發現bug時常首先是從UI顯示發現例外,下一步才會去定位UI相關連的資料的。XCode有給我們提供一系列debug工具,但是很多人可能還沒有形成一套穩定的除錯流程,因此本文嘗試解決這個問題,順便提出一個暴論:UI顯示例外問題只需要兩個步驟就能完成定位作業的80%: 定位例外 UI 組 ......

    uj5u.com 2023-04-19 09:14:53 more
  • FIDE重磅更新!性能飛躍!體驗有禮!

    FIDE 開發者工具重構升級啦!實作500%性能提升,誠邀體驗! 一直以來不少開發者朋友在社區反饋,在使用 FIDE 工具的程序中,時常會遇到諸如加載不及時、代碼預覽/渲染性能不如意的情況,十分影響開發體驗。 作為技術團隊,我們深知一件趁手的開發工具對開發者的重要性,因此,在2023年開年,FinC ......

    uj5u.com 2023-04-19 09:14:08 more
  • 游戲內嵌社區服務開放,助力開發者提升玩家互動與留存

    華為 HMS Core 游戲內嵌社區服務提供快速訪問華為游戲中心論壇能力,支持玩家直接在游戲內瀏覽帖子和交流互動,助力開發者擴展內容生產和觸達的場景。 一、為什么要游戲內嵌社區? 二、游戲內嵌社區的典型使用場景 1、游戲內打開論壇 您可以在游戲內繪制論壇入口,為玩家提供沉浸式發帖、瀏覽、點贊、回帖、 ......

    uj5u.com 2023-04-19 09:08:34 more