數據庫學習筆記(十六)--控住流程與游標

在這里插入圖片描述
前言

  • 學習和使用數據庫可以說是程序員必須具備能力,這里將更新關于MYSQL的使用講解,大概應該會更新30篇+,涵蓋入門、進階、高級(一些原理分析);
  • 這一篇和上一篇差不多,當做擴展,用到的時候再查即可(畢竟數據庫最多的還是增刪改查 )。這一篇很像我們常用的高級語言的基礎課程
  • 雖然MYSQL命令很多,但是自己去多敲一點,到后面忘記了,查一下就可以回憶起來使用了;
  • 這一系列也是本人學習MYSQL做的筆記,也是為了方便后面忘記查詢;
  • 參考資料:黑馬、csdn和知乎博客;
  • 歡迎收藏 + 關注,本人將會持續更新后端和AI算法的學習筆記

    文章目錄

      • 1. 流程控制
        • 1.1 分支結構之 IF
        • 1.2 分支結構之 CASE
        • 1.3 循環結構之 LOOP
        • 1.4 循環結構之 WHILE
        • 1.5 循環結構之 REPEAT
        • 1.6 跳轉語句之 LEAVE語句
        • 1.7 跳轉語句之 ITERATE 語句
      • 2. 游標
        • 2.1 什么是游標(或光標)
        • 4.2 使用游標步驟
        • 2.3 舉例
        • 2.4 小結

1. 流程控制

解決復雜問題不可能通過一個 SQL 語句完成,我們需要執行多個 SQL 操作。流程控制語句的作用就是控制存儲過程中 SQL 語句的執行順序,是我們完成復雜操作必不可少的一部分。只要是執行的程序,流程就分為三大類:

  • 順序結構 :程序從上往下依次執行
  • 分支結構 :程序按條件進行選擇執行,從兩條或多條路徑中選擇一條執行
  • 循環結構 :程序滿足一定條件下,重復執行一組語句

針對于MySQL 的流程控制語句主要有 3 類。注意:只能用于存儲程序。

  • 條件判斷語句 :IF 語句和 CASE 語句
  • 循環語句 :LOOP、WHILE 和 REPEAT 語句
  • 跳轉語句 :ITERATE (iterate)和 LEAVE (leave)語句

1.1 分支結構之 IF

IF 語句的語法結構是:

IF 表達式1 THEN 操作1
[ELSEIF 表達式2 THEN 操作2] 
...
[ELSE 操作N]     #注意:else沒有then
END IF

根據表達式的結果為TRUE或FALSE執行相應的語句。這里“[]”中的內容是可選的。

  • 特點:① 不同的表達式對應不同的操作

? ②使用在begin end中

  • 范例1:
IF val IS NULL
THEN SELECT 'val is null';
ELSE SELECT 'val is not null';	  #注意:else沒有then
END IF

**范例2:**聲明存儲過程“update_sal_by_eno”,定義IN參數eno,輸入員工編號。判斷該員工 薪資如果低于2000元并且入職時間超過5年,就漲薪500元;否則就不變。

CREATE PROCEDURE update_sal_by_eno1(IN eno INT) 
BEGINDECLARE emp_sal DOUBLE; DECLARE hire_year DOUBLE;SELECT sal INTO emp_sal FROM emps WHERE empno = eno;SELECT DATEDIFF(CURDATE(),hiredate)/365 INTO hire_year FROM emps WHERE empno = eno;IF emp_sal < 2000 AND hire_year > 5THEN UPDATE emps SET sal = sal + 500 WHERE empno = eno; END IF;
END ;

**范例3:**聲明存儲過程“update_sal_by_eno2”,定義IN參數eno,輸入員工編號。判斷該員工 薪資如果低于3000元,就更新薪資為3000元;薪資如果大于等于3000元且低于5000的,但是獎金 比例為NULL的,就更新獎金比例為0.01;其他的漲薪100元。

DELIMITER //
CREATE PROCEDURE update_sal_by_eno2(IN eno INT) 
BEGINDECLARE emp_sal DOUBLE; DECLARE emp_comm DECIMAL(5,2);SELECT sal INTO emp_sal FROM emps WHERE empno = eno; SELECT comm INTO emp_comm FROM emps WHERE empno = eno;IF emp_sal < 3000THEN UPDATE emps SET sal = 3000 WHERE empno = eno;SELECT '1';ELSEIF emp_sal < 5000 AND emp_comm IS NULLTHEN UPDATE emps SET comm = 0.01*sal WHERE empno = eno;SELECT '2';ELSE   #注意:else沒有thenUPDATE emps SET sal = sal + 100 WHERE empno = eno; SELECT '3';END IF;
END //
DELIMITER //

1.2 分支結構之 CASE

CASE 語句的語法結構1:

#情況一:類似于switch 
CASE 表達式
WHEN 值1 THEN 結果1或語句1(如果是語句,需要加分號) 
WHEN 值2 THEN 結果2或語句2(如果是語句,需要加分號)
...
ELSE 結果n或語句n(如果是語句,需要加分號)
END [case](如果是放在begin end中需要加上case,如果放在select后面不需要)

CASE 語句的語法結構2:

#情況二:類似于多重if 
CASE
WHEN 條件1 THEN 結果1或語句1(如果是語句,需要加分號)
WHEN 條件2 THEN 結果2或語句2(如果是語句,需要加分號)
...
ELSE 結果n或語句n(如果是語句,需要加分號)
END [case](如果是放在begin end中需要加上case,如果放在select后面不需要)

**范例1:**使用CASE流程控制語句的第1種格式,判斷val值等于1、等于2,或者兩者都不等。

CASE valWHEN 1 THEN SELECT 'val is 1'; WHEN 2 THEN SELECT 'val is 2';ELSE SELECT 'val is not 1 or 2'; 
END CASE;

**范例2:**使用CASE流程控制語句的第2種格式,判斷val是否為空、小于0、大于0或者等于0。

CASEWHEN val IS NULL THEN SELECT 'val is null'; WHEN val < 0 THEN SELECT 'val is less than 0';WHEN val > 0 THEN SELECT 'val is greater than 0'; ELSE SELECT 'val is 0';
END CASE;

**范例3:**聲明存儲過程“update_salary_by_eno4”,定義IN參數eno,輸入員工編號。判斷改員工所屬部門,如果在10號部門,工資加500;如果在20號部門,工資加600;如果在30號部門,工資加700;其他部門加300。

CREATE PROCEDURE update_salary_by_eno4(IN eno INT) 
BEGINDECLARE dept_no,emp_sal INT; SELECT sal,deptno INTO emp_sal,dept_no FROM emps WHERE empno = eno; CASE deptnoWHEN 10THEN UPDATE emps SET sal=emp_sal+500 WHERE empno = eno; WHEN 20THEN UPDATE emps SET sal=emp_sal+600 WHERE empno = eno; WHEN 30THEN UPDATE emps SET sal=emp_sal+700 WHERE empno = eno;ELSE UPDATE emps SET sal=emp_sal+300 WHERE empno = eno;	END CASE;
END //

**范例4:**聲明存儲過程pro_sal_grade,定義IN參數eno,輸入員工編號。判斷該員工的薪資等級,如果在[700,1200]之間,為等級一;如果在[1201,1400]之間,為等級二;如果在[1401,2000]之間,為等級三;如果在[2001,3000]之間,為等級四;如果在[3001,9999]之間,為等級五;

CREATE PROCEDURE sal_grade(IN eno INT) 
BEGINDECLARE emp_sal INT; SELECT sal INTO emp_sal FROM emps WHERE empno = eno;CASE WHEN emp_sal>=700 AND emp_sal<=1200THEN SELECT '等級一'; 			WHEN emp_sal>=1201 AND emp_sal<=1400 THEN SELECT '等級二';		WHEN emp_sal>=1401 AND emp_sal<=2000 	THEN SELECT '等級三';WHEN emp_sal>=2001 AND emp_sal<=3000 THEN SELECT '等級四';WHEN emp_sal>=3001 AND emp_sal<=999 THEN SELECT '等級五';END CASE;
END //

1.3 循環結構之 LOOP

LOOP循環語句用來重復執行某些語句。LOOP內的語句一直重復執行直到循環被退出(使用LEAVE子 句),跳出循環過程。

LOOP語句的基本格式如下:

[loop_label:] LOOP循環執行的語句
END LOOP [loop_label] 

其中,loop_label表示LOOP語句的標注名稱,該參數可以省略。

**范例1:**使用LOOP語句進行循環操作,id值小于10時將重復執行循環過程。

DECLARE id INT DEFAULT 0;
add_loop:LOOPSET id = id +1;IF id >= 10 THEN LEAVE add_loop; END IF;END LOOP add_loop;

**范例2:**當市場環境變好時,公司為了獎勵大家,決定給大家漲工資。聲明存儲過程“update_sal_loop()”,聲明OUT參數num,輸出循環次數。存儲過程中實現循環給大家漲薪,薪資漲為原來的1.1倍。直到全公司的平均薪資達到8000結束。并統計循環次數。

CREATE PROCEDURE update_sal_loop(OUT num INT) 
BEGINDECLARE avg_sal DOUBLE; DECLARE loop_count INT DEFAULT 0;SELECT AVG(sal) INTO avg_sal FROM emps;label_loop:LOOPIF avg_sal >= 8000 THEN LEAVE label_loop;   #離開語句END IF;UPDATE emps SET sal = sal * 1.1; SET loop_count = loop_count + 1;SELECT AVG(sal) INTO avg_salary FROM emps; END LOOP label_loop;SET num = loop_count; 
END ;

1.4 循環結構之 WHILE

WHILE語句創建一個帶條件判斷的循環過程。WHILE在執行語句執行時,先對指定的表達式進行判斷,如 果為真,就執行循環內的語句,否則退出循環。WHILE語句的基本格式如下:

[while_label:] WHILE 循環條件 DO循環體
END WHILE [while_label];

while_label為WHILE語句的標注名稱;如果循環條件結果為真,WHILE語句內的語句或語句群被執行,直 至循環條件為假,退出循環。

**范例1:**WHILE語句示例,i值小于10時,將重復執行循環過程,代碼如下:

CREATE PROCEDURE test_while()
BEGINDECLARE i INT DEFAULT 0;WHILE i < 10 DO SET i = i + 1;END WHILE;SELECT i;
END ;
#調用
CALL test_while();

**范例2:**市場環境不好時,公司為了渡過難關,決定暫時降低大家的薪資。聲明存儲過程“update_salary_while()”,聲明OUT參數num,輸出循環次數。存儲過程中實現循環給大家降薪,薪資降為原來的90%。直到全公司的平均薪資達到3000結束。并統計循環次數。

CREATE PROCEDURE update_sal_while(OUT num INT) 
BEGINDECLARE avg_sal DOUBLE ;DECLARE while_count INT DEFAULT 0;SELECT AVG(sal) INTO avg_sal FROM emps; WHILE avg_sal > 3000 DOUPDATE emps SET sal = sal * 0.9; SET while_count = while_count + 1;SELECT AVG(sal) INTO avg_sal FROM emps; END WHILE;SET num = while_count; 
END //

1.5 循環結構之 REPEAT

REPEAT語句創建一個帶條件判斷的循環過程。與WHILE循環不同的是,REPEAT 循環首先會執行一次循環,然后在 UNTIL 中進行表達式的判斷,如果滿足條件就退出,即 END REPEAT;如果條件不滿足,則會就繼續執行循環,直到滿足退出條件為止。

REPEAT語句的基本格式如下:

[repeat_label:] REPEAT循環體的語句
UNTIL 結束循環的條件表達式
END REPEAT [repeat_label]

repeat_label為REPEAT語句的標注名稱,該參數可以省略;REPEAT語句內的語句或語句群被重復,直至expr_condition為真。

范例1:

CREATE PROCEDURE test_repeat() 
BEGINDECLARE i INT DEFAULT 0;REPEATSET i = i + 1; UNTIL i >= 10END REPEAT;SELECT i;
END ;

**范例2:**當市場環境變好時,公司為了獎勵大家,決定給大家漲工資。聲明存儲過程“update_salary_repeat()”,聲明OUT參數num,輸出循環次數。存儲過程中實現循環給大家漲薪,薪資漲為原來的1.15倍。直到全公司的平均薪資達到9000結束。并統計循環次數。

CREATE PROCEDURE update_salary_repeat(OUT num INT) 
BEGINDECLARE avg_sal DOUBLE ;DECLARE repeat_count INT DEFAULT 0;SELECT AVG(sal) INTO avg_sal FROM emps; REPEATUPDATE emps SET sal = sal * 1.15;SET repeat_count = repeat_count + 1;SELECT AVG(sal) INTO avg_sal FROM emps; UNTIL avg_sal >= 9000END REPEAT;SET num = repeat_count; 
END //

對比三種循環結構:

1、這三種循環都可以省略名稱,但如果循環中添加了循環控制語句(LEAVE或ITERATE)則必須添加名稱。

2、 LOOP:一般用于實現簡單的"死"循環 WHILE:先判斷后執行 REPEAT:先執行后判斷,無條件至少執行一次

1.6 跳轉語句之 LEAVE語句

LEAVE語句:可以用在循環語句內,或者以 BEGIN 和 END 包裹起來的程序體內,表示跳出循環或者跳出程序體的操作(相當于break);

基本格式如下:

LEAVE 標記名

其中,label參數表示循環的標志。LEAVE和BEGIN … END或循環一起被使用。

**范例1:**創建存儲過程 “leave_begin()”,聲明INT類型的IN參數num。給BEGIN…END加標記名,并在BEGIN…END中使用IF語句判斷num參數的值。

  • 如果num<=0,則使用LEAVE語句退出BEGIN…END;
  • 如果num=1,則查詢“emps”表的平均薪資;
  • 如果num=2,則查詢“emps”表的最低薪資;
  • 如果num>2,則查詢“emps”表的最高薪資。

IF語句結束后查詢“emp”表的總人數。

CREATE PROCEDURE leave_begin(IN num INT) begin_label: BEGINIF num<=0THEN LEAVE begin_label; ELSEIF num=1THEN SELECT AVG(sal) FROM emps; ELSEIF num=2THEN SELECT MIN(sal) FROM emps; ELSESELECT MAX(sal) FROM emps; END IF;SELECT COUNT(*) FROM emps; 
END ;

**范例2:**當市場環境不好時,公司為了渡過難關,決定暫時降低大家的薪資。聲明存儲過程“leave_while()”,聲明OUT參數num,輸出循環次數,存儲過程中使用WHILE循環給大家降低薪資為原來薪資的90%,直到全公 司的平均薪資小于等于10000,并統計循環次數。

CREATE PROCEDURE leave_while(OUT num INT)
BEGIN#DECLARE avg_sal DOUBLE;#記錄平均工資DECLARE while_count INT DEFAULT 0; #記錄循環次數SELECT AVG(sal) INTO avg_sal FROM emps; #① 初始化條件while_label:WHILE TRUE DO #② 循環條件#③ 循環體IF avg_sal <= 10000 THEN LEAVE while_label;END IF;UPDATE emps SET sal = sal * 0.9; SET while_count = while_count + 1;#④ 迭代條件SELECT AVG(sal) INTO avg_sal FROM emps; END WHILE;#賦值SET num = while_count; 
END ;

1.7 跳轉語句之 ITERATE 語句

ITERATE(iterate)語句只能用在循環語句(LOOP、REPEAT和WHILE語句)內,表示重新開始循環,將執行順序 轉到語句段開頭處(continue).

語句基本格式如下:

ITERATE label

label參數表示循環的標志。ITERATE語句必須跟在循環標志前面。

范例: 定義局部變量num,初始值為0。循環結構中執行num + 1操作。

  • 如果num < 10,則繼續執行循環;
  • 如果num > 15,則退出循環結構;
CREATE PROCEDURE test_iterate() 
BEGINDECLARE num INT DEFAULT 0;my_loop:LOOPSET num = num + 1;IF num < 10THEN ITERATE my_loop; ELSEIF num > 15THEN LEAVE my_loop; END IF;SELECT '頓開教育:讓每個學員都學有所成'; END LOOP my_loop;
END //

2. 游標

2.1 什么是游標(或光標)

雖然我們也可以通過篩選條件 WHERE 和 HAVING,或者是限定返回記錄的關鍵字 LIMIT 返回一條記錄, 但是,卻無法在結果集中像指針一樣,向前定位一條記錄、向后定位一條記錄,或者是隨意定位到某一條記錄 ,并對記錄的數據進行處理。

這個時候,就可以用到游標。在 SQL 中,游標是一種臨時的數據庫對象,可以指向存儲在數據庫表中的數據行指針。說白了就是可以逐行讀取。


MySQL中游標可以在存儲過程和函數中使用。

比如,我們查詢了 emps數據表中工資高于1500的員工都有哪些:

SELECT empno,ename,sal FROM emps WHERE sal > 1500;

在這里插入圖片描述

這里我們就可以通過游標來操作數據行,如圖所示此時游標所在的行是“7698”的記錄,我們也可以在結果集上滾動游標,指向結果集中的任意一行。

4.2 使用游標步驟

游標必須在聲明處理程序之前被聲明,并且變量和條件還必須在聲明游標或處理程序之前被聲明。 如果我們想要使用游標,一般需要經歷四個步驟。

第一步,聲明游標

在MySQL中,使用DECLARE關鍵字來聲明游標,其語法的基本形式如下:

DECLARE cursor_name CURSOR FOR select_statement;

這個語法適用于 MySQL,SQL Server,DB2 和 MariaDB。如果是用 Oracle 或者 PostgreSQL,需要寫成:

DECLARE cursor_name CURSOR IS select_statement;

要使用 SELECT 語句來獲取數據結果集,而此時還沒有開始遍歷數據,這里 select_statement 代表的是

SELECT 語句,返回一個用于創建游標的結果集。

比如:

DECLARE cur_emp CURSOR FOR
SELECT empno,sal FROM emps;
DECLARE cursor_dept CURSOR FOR 
SELECT deptno,dname, loc FROM depts ;

第二步,打開游標

打開游標的語法如下:

OPEN cursor_name

當我們定義好游標之后,如果想要使用游標,必須先打開游標。

打開游標的時候 SELECT 語句的查詢結果集就會送到游標工作區,為后面游標的 逐條讀取 結果集中的記錄做準備。

OPEN cur_emp ;

第三步,使用游標(從游標中取得數據)

語法如下:

FETCH cursor_name INTO var_name [, var_name] ...

這句的作用是使用 cursor_name 這個游標來讀取當前行,并且將數據保存到 var_name 這個變量中,游標指針指到下一行。如果游標讀取的數據行有多個列名,則在 INTO 關鍵字后面賦值給多個變量名即可。

注意:var_name必須在聲明游標之前就定義好。

FETCH cur_emp INTO emp_no, emp_sal ;

注意:游標的查詢結果集中的字段數,必須跟 INTO 后面的變量數一致,否則,在存儲過程執行的時候,MySQL 會提示錯誤。

第四步,關閉游標

CLOSE cursor_name

有 OPEN 就會有 CLOSE,也就是打開和關閉游標。當我們使用完游標后需要關閉掉該游標。因為游標會占用系統資源 ,如果不及時關閉,游標會一直保持到存儲過程結束,影響系統運行的效率。而關閉游標的操作,會釋放游標占用的系統資源。

關閉游標之后,我們就不能再檢索查詢結果中的數據行,如果需要檢索只能再次打開游標。

CLOSE cur_emp; 

2.3 舉例

創建存儲過程“get_count_by_limit_total_salary()”,聲明IN參數 limit_total_salary;聲明OUT參數total_count。函數的功能可以實現累加薪資最高的幾個員工的薪資值,直到薪資總和 達到limit_total_salary參數的值,返回累加的人數給total_count。

CREATE PROCEDURE get_count_by_limit_total_salary(IN limit_total_sal INT,OUT total_count INT)
BEGIN#聲明變量DECLARE sum_sal INT DEFAULT  0;		#記錄累加的總工資DECLARE emp_count INT DEFAULT  0;	#記錄循環總次數DECLARE emp_sal INT;							#當前員工的工資#聲明游標DECLARE  cursor_emp CURSOR FOR SELECT sal FROM emp ORDER BY sal DESC;#打開游標OPEN cursor_emp;#使用游標WHILE sum_sal < limit_total_sal DOFETCH cursor_emp INTO emp_sal;SET sum_sal = emp_sal+sum_sal;SET emp_count = emp_count+1;END WHILE;#關閉游標CLOSE cursor_emp;#設置傳出參數值SET total_count = emp_count;
END;

2.4 小結

游標是 MySQL 的一個重要的功能,為逐條讀取結果集中的數據,提供了完美的解決方案。跟在應用層面實現相同的功能相比,游標可以在存儲程序中使用,效率高,程序也更加簡潔。

但是在并發過程會對數據進行加鎖,影響速度,故最好用完就解鎖。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/84798.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/84798.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/84798.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《Origin畫百圖》之核密度圖

核密度圖&#xff08;Kernel Density Plot&#xff09; 是一種用于展示數據分布形態的可視化工具&#xff0c;它通過平滑的曲線來估計數據的概率密度函數&#xff0c;相比直方圖能更細膩地呈現數據的分布特征。 具體步驟&#xff1a; &#xff08;1&#xff09;選中數據&#…

使用Apache POI操作Word文檔:從入門到實戰

Apache POI是Java生態中最流行的Microsoft Office文檔操作庫之一&#xff0c;它為Word文檔&#xff08;包括傳統的.doc格式和現代的.docx格式&#xff09;提供了全面的API支持。本文將詳細介紹如何使用Apache POI創建、讀取和修改Word文檔。 一、Apache POI簡介與環境準備 1.…

CentOS 7.3環境中部署Kerberos集群

CentOS 7.3環境中部署Kerberos集群 文章目錄 CentOS 7.3環境中部署Kerberos集群環境安裝服務包 Kerberos MS 規劃安裝 KDC Master Server配置文件/etc/krb5.conf/var/kerberos/krb5kdc/kdc.conf/var/kerberos/krb5kdc/kadm5.acl 創建Kerberos數據庫啟動與停止服務創建管理員創建…

1 Studying《Arm A715 Software Optimization Guide》

目錄 1 Introduction 1.1 Product revision status 1.2 Intended audience 1.3 Scope 1.4 Conventions 1.5 Useful resources 2 Overview 2.1 Pipeline overview 3 Instruction characteristics 3.1 Instruction tables 3.2 Legend for reading the utilized pipeli…

第二十四章 24.QoS(CCNA)

第二十四章 24.QoS(CCNA) 介紹了switch QoS的配置方法 注釋&#xff1a; 學習資源是B站的CCNA by Sean_Ning CCNA 最新CCNA 200-301 視頻教程(含免費實驗環境&#xff09; PS&#xff1a;喜歡的可以去買下他的課程&#xff0c;不貴&#xff0c;講的很細 To be continued……

什么是穩定幣?

穩定幣&#xff08;Stablecoin&#xff09;是一種特殊的加密貨幣&#xff0c;其核心目標是維持價格穩定&#xff0c;通常與某種穩定資產&#xff08;如美元、黃金等&#xff09;掛鉤。 一、為什么需要穩定幣&#xff1f; 普通加密貨幣&#xff08;如比特幣、以太坊&#xff09…

伺服學習(IS620N)

DI 端子的基本概念 DI 端子是伺服驅動器上的數字輸入接口&#xff0c;用于接收外部開關、按鈕或PLC的24V/0V信號。每個端子的功能可通過參數靈活配置&#xff08;如啟停、限位等&#xff09;。 核心要點 功能設置&#xff1a;通過驅動器參數組&#xff08;如H03&#xff09;…

基于Python的氣象數據分析及可視化研究

目錄 一.&#x1f981;前言二.&#x1f981;開源代碼與組件使用情況說明三.&#x1f981;核心功能1. ?算法設計2. ?PyEcharts庫3. ?Flask框架4. ?爬蟲5. ?部署項目 四.&#x1f981;演示效果1. 管理員模塊1.1 用戶管理 2. 用戶模塊2.1 登錄系統2.2 查看實時數據2.3 查看天…

Excel處理控件Aspose.Cells教程:使用 C# 在 Excel 中應用數據驗證

Excel 中的數據驗證可確保用戶在工作表中僅輸入有效數據。在設計表單、收集數據或構建財務模型時&#xff0c;數據驗證有助于維護結構并最大限度地減少用戶錯誤。在本文中&#xff0c;我們將向您展示如何使用 C# 以編程方式在 Excel 中應用數據驗證。 Aspose.Cells 最新版下載…

AI應用:計算機視覺相關技術總結

計算機視覺概述 計算機視覺&#xff08;Computer Vision, CV&#xff09;是一門讓計算機從圖像或視頻中 “理解” 和 “解釋” 視覺信息的技術&#xff0c;涉及多學科交叉&#xff08;如數學、統計學、機器學習、信號處理等&#xff09;。以下從技術體系、核心任務、關鍵技術、…

人口販賣暑期威脅消解:算法協同提升安全預警

隨著暑期的到來&#xff0c;人員流動加劇&#xff0c;人口販賣等惡性犯罪活動進入高發階段&#xff0c;景區、車站、商場等公共場所成為潛在風險區域。傳統安防手段在應對此類隱蔽性強、危害性大的犯罪時顯得力不從心。為此&#xff0c;引入基于視覺分析的多維度算法技術&#…

【DSP筆記 · 第3章】數字世界的“棱鏡”:離散傅里葉變換(DFT)完全解析

數字世界的“棱鏡”&#xff1a;離散傅里葉變換&#xff08;DFT&#xff09;完全解析 在上一章&#xff0c;我們探索了Z變換和離散時間傅里葉變換&#xff08;DTFT&#xff09;。我們知道&#xff0c;DTFT是一個無比強大的理論工具&#xff0c;它能將一個時域離散序列的“基因…

卷積神經網絡的參數量及尺度變化計算

文章目錄 前言1.卷積2.參數量的計算2.1案例一2.2案例二 3.奇怪的優化思想3.1使用小核卷積替換大核卷積3.2卷積核11的應用 4.輸出圖像尺寸的計算4.1Same convolution4.2具體計算規則4.3轉置卷積 小結 前言 本篇博客主要介紹卷積基本概念&#xff0c;卷積神經網絡的參數量計算、…

OpenCV——圖像平滑

圖像平滑 一、圖像的噪聲1.1、噪聲來源1.2、噪聲類型1.3、噪聲模擬 二、濾波器三、線性濾波3.1、均值濾波3.2、方框濾波3.3、高斯濾波 四、非線性濾波4.1、中值濾波4.2、雙邊濾波 圖像在采集和傳輸過程中容易受到各種因素的影響而產生噪聲&#xff0c;而噪聲會對圖像的正確解讀…

鴻蒙系統備份恢復

鴻蒙系統嘗試者&#xff0c;在純血鴻蒙與鴻蒙4.2/4.3之前反復橫跳&#xff0c;中間折騰… 目錄 鴻蒙4.2/4.3升級鴻蒙5.0系統備份 鴻蒙5.0回退鴻蒙4.2/4.3系統備份備份恢復 華為手機助手注意 鴻蒙4.2/4.3升級鴻蒙5.0 系統備份 云空間備份手機本地備份華為手機助手備份 鴻蒙5.…

JS進階 Day03

1.兩種面向編程思想 2.構造函數實現封裝以及存在的問題 下面就引出了原型對象 3.原型對象prototype 共享原理圖&#xff1a; 4.數組擴展案例-求最大值和數組求和 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><…

visual studio小番茄插件某些快捷鍵失效

問題 AltO 切換頭文件和源文件失效。 背景 最近升級了 visual studio&#xff0c;多了一些插件 原因 Alt O 快捷鍵被其他插件占用了 解決方案 工具 → 選項 → 環境 → 鍵盤 搜索這個 VAssistX.OpenCorrespondingFile&#xff08;切換頭/源文件&#xff09; 發現命令的快…

基于單片機的PT100溫度變送器設計

基于單片機的PT100溫度變送器設計 文章目錄 基于單片機的PT100溫度變送器設計前言一、資源分享二、系統框架三、硬件準備1.主控制器2、PT100溫度傳感器3、顯示屏4、WIFI模塊5、USB轉RS485模塊6、SP3485EN7、K11-11D3 四、設計PCB1、安裝下載立創EDA專業版2、畫原理圖3、擺放元器…

Git 清理指南:如何從版本庫中移除誤提交的文件(保留本地文件)

場景 在 Git 項目中&#xff0c;我們可能會不小心提交了本應忽略的文件&#xff08;如 node_modules/、.env、*.log 等&#xff09;&#xff0c;導致倉庫體積膨脹或敏感信息泄露。本文介紹如何從 Git 歷史中徹底刪除這些文件&#xff0c;同時保留本地文件。 解決方案 1. 確認…

服務器數據恢復—重裝系統導致XFS文件系統分區無法訪問的數據恢復案例

服務器數據恢復環境&故障&#xff1a; 一臺服務器上通過磁盤柜RAID卡組建的riad5磁盤陣列&#xff0c;服務器上層安裝Linux操作系統&#xff0c;搭建XFS文件系統。服務器上層分配一個LUN&#xff0c;并劃分了兩個分區。通過LVM擴容的方式將sdc1分區加入到了root_lv中&#…