工作中sql總結

sql總結

  • 場景1分組后失敗的成功數據帶入
  • 場景2完全性質的一對一匹配
  • 場景3虛擬戶的特殊匹配
  • 場景4多對多匹配
  • 場景5一對一匹配
  • 場景6 一對多匹配

場景1分組后失敗的成功數據帶入

現有一批交易表的數據,根據戶名,日期,金額分組,存在TRADE_STATUS 有成功和失敗的情況,
而失敗的FUNDFLOW_DETAILS_ID字段已和資金表的FUNDFLOW_DETAILS_ID匹配。
現需要將成功的憑證號和期間根據";"拼接到一起,存儲到與該組失敗數據匹配的資金表的數據中,存儲到JOURNAL_VOUCHER_NUMBER和ACCOUNT_DATE 字段

使用
HAVING
sum(CASE WHEN a.TRADE_STATUS = ‘失敗’ THEN 1 ELSE 0 END) >=1
AND
sum(CASE WHEN a.TRADE_STATUS = ‘成功’ THEN 1 ELSE 0 END) >=1
判斷該分組下是否至少有一條成功的數據和一條失敗的數據

DECLARE CURSOR res_data IS SELECT a.CUSTOMER_ACCOUNT_NAME_ORIGIN,TRUNC(a.TRADE_DATE_BAK) AS ts_date,a.TRADE_AMOUNTFROM RC_TRADEFLOW_DETAILS_NAPR aWHERE 1=1AND a.OURS_ACCOUNT_NUMBER  LIKE '%02222' GROUP BY a.CUSTOMER_ACCOUNT_NAME_ORIGIN,TRUNC(a.TRADE_DATE_BAK),a.TRADE_AMOUNT HAVING sum(CASE WHEN a.TRADE_STATUS  = '失敗' THEN 1 ELSE 0 END) >=1ANDsum(CASE WHEN a.TRADE_STATUS = '成功' THEN 1 ELSE 0 END) >=1;a_vouchers varchar2(4000);a_periods varchar2(4000);
BEGIN 	 FOR s IN res_data LOOPSELECT EXTRACT(XMLAGG(XMLELEMENT(e, pz, ';') ORDER BY pz),'/E/text()').GETCLOBVAL() INTO a_vouchersFROM (SELECT DISTINCT a.JOURNAL_VOUCHER_NUMBER  as pzFROM RC_TRADEFLOW_DETAILS_NAPR a WHERE 1=1AND a.OURS_ACCOUNT_NUMBER  LIKE '%2222'AND a.CUSTOMER_ACCOUNT_NAME_ORIGIN = s.CUSTOMER_ACCOUNT_NAME_ORIGINAND TRUNC(a.TRADE_DATE_BAK) = s.ts_dateAND a.TRADE_AMOUNT = s.TRADE_AMOUNTAND a.TRADE_STATUS = '成功');SELECT EXTRACT(XMLAGG(XMLELEMENT(e, qj, ';') ORDER BY qj),'/E/text()').GETCLOBVAL() INTO a_periodsFROM (SELECT DISTINCT a.ACCOUNT_DATE  as qjFROM RC_TRADEFLOW_DETAILS_NAPR a WHERE 1=1AND a.OURS_ACCOUNT_NUMBER  LIKE '%02222'AND a.CUSTOMER_ACCOUNT_NAME_ORIGIN = s.CUSTOMER_ACCOUNT_NAME_ORIGINAND TRUNC(a.TRADE_DATE_BAK) = s.ts_dateAND a.TRADE_AMOUNT = s.TRADE_AMOUNTAND a.TRADE_STATUS = '成功');UPDATE RC_FUNDFLOW_DETAILS_NAPR A SET a.JOURNAL_VOUCHER_NUMBER  = a_vouchers,a.ACCOUNT_DATE = a_periods,a.RULER_NAME_TRADEFLOW  = '失敗和成功同一批次,失敗已經和資金表的資金流水編號匹配,將成功的憑證號拼接帶入那個資金'WHERE 1=1AND a.OURS_ACCOUNT_NUMBER  LIKE '%02222'AND a.FUNDFLOW_DETAILS_ID  IN (SELECT DISTINCT b.FUNDFLOW_DETAILS_ID FROM RC_TRADEFLOW_DETAILS_NAPR b WHERE 1=1AND b.OURS_ACCOUNT_NUMBER  LIKE '%02222'AND b.CUSTOMER_ACCOUNT_NAME_ORIGIN = s.CUSTOMER_ACCOUNT_NAME_ORIGINAND TRUNC(b.TRADE_DATE_BAK) = s.ts_dateAND b.TRADE_AMOUNT = s.TRADE_AMOUNTAND b.TRADE_STATUS = '失敗');END LOOP;COMMIT;
END;

場景2完全性質的一對一匹配

現有一批數據,企業表和交易表已經匹配大量數據,但還有剩余,剩余數據匹配規則如下:
1.兩批數據必須在賬戶,戶名,日期,金額分組下僅有一條,防止匹配錯亂,
2.按照賬戶,戶名,日期,金額進行匹配
3.將企業表的憑證號和期間帶入資金。
使用窗口函數,在不影響性能的情況下,快速判斷該數據在該分區下該條數據是否僅有一條

BEGINFOR s in (
SELECTqy.DOC_SEQUENCE_VALUE,qy.PERIOD_NAME,zj.URIDfrom(SELECTls.mydate,ls.CUSTOMER_NAME,ls.money,ls.DOC_SEQUENCE_VALUE,ls.PERIOD_NAMEFROM(SELECTTO_CHAR(DEFAULT_EFFECTIVE_DATE, 'YYYY-MM-dd') AS mydate,CUSTOMER_NAME,(CASE WHEN ENTERED_DR <> 0 THEN ENTERED_DR ELSE -ENTERED_CR end) AS money,DOC_SEQUENCE_VALUE,PERIOD_NAME,count(*) OVER(PARTITION BY TO_CHAR(DEFAULT_EFFECTIVE_DATE, 'YYYY-MM-dd'),CUSTOMER_NAME,ENTERED_DR,ENTERED_CR) AS partition_countFROM rc_fin_transactions WHERE 1=1 AND BANKACCNO_SID = (select sid from RC_BANKACCDEF  where BANKACCNO like '%11111'))lsWHERE ls.partition_count = 1) qyINNER JOIN (SELECTls.mydate,ls.DF_ACCOUNTNAME,ls.AMOUNT,ls.URIDFROM(SELECTTO_CHAR(POSTDATETIME, 'YYYY-MM-dd') AS mydate,DF_ACCOUNTNAME,AMOUNT,URID,COUNT(*) OVER (PARTITION BY TO_CHAR(POSTDATETIME, 'YYYY-MM-dd'), DF_ACCOUNTNAME, AMOUNT) AS partition_countFROM ISSUE202412_RECON_ZJLSBWHERE wf_account LIKE '%11111' AND 企業賬憑證號 IS NULL) lsWHERE ls.partition_count = 1) zjon qy.mydate = TO_CHAR(TO_DATE(zj.mydate,'YYYY-MM-DD')+1,'YYYY-MM-DD') AND qy.CUSTOMER_NAME = zj.DF_ACCOUNTNAME AND qy.money = zj.amount) LOOP
-- 將企業的憑證號和期間帶入資金
update ISSUE202412_RECON_ZJLSB
set 企業賬憑證號 = s.DOC_SEQUENCE_VALUE,企業賬期間 = s.PERIOD_NAME,規則名稱 = '日期+戶名+單筆金額1對1企業直接帶入資金'
where URID = s.URID;
END LOOP;
COMMIT;
END;

場景3虛擬戶的特殊匹配

現有交易表和資金表數據,要求交易表和資金表按照日期(天)匹配,
規則:
1.如果交易表當天的所有數據能夠資金表當天的數據按照日期(天)匹配,那就按當天匹配
2.如果資金表中當天不存在數據,那就找到比當前交易表日期小的資金表中存在的最大的日期進行匹配
3.如果資金表中既不存在當天數據,也不存在比當前交易表日期小的資金表中存在的最大的日期
那就找到比當前交易表日期大的資金表中存在的最小日期進行匹配。
總結:就近匹配
將與交易表當天匹配的資金表的那天的所有FUNDSFLOWCODE進行拼接,放入交易表當天的每一條數據中。

將日期匹配條件進行優化,
原先TRUNC(TRADE_DATE_BAK) = rec.TRADE_DATE_BAK 因為牽涉到函數計算字段,導致索引失效,
優化為范圍查詢,大大提升性能
AND d.postdatetime >= rec.TRADE_DATE_BAK
AND d.postdatetime < rec.TRADE_DATE_BAK + 1
優化原理,TRUNC會截取到日期的天如2025-01-03 23:33:13.111會被截取為2025-01-03 00:00:00.000
,故那天的所有日期都會被截取為2025-01-03 00:00:00.000,如果想獲取當天的所有日期,僅需找到當天日期范圍在
[2025-01-03 00:00:00.000,2025-01-04 00:00:00.000)也就是
AND d.postdatetime >= rec.TRADE_DATE_BAK
AND d.postdatetime < rec.TRADE_DATE_BAK + 1

DECLARECURSOR cur_data ISSELECT DISTINCT TRUNC(TRADE_DATE_BAK)  AS TRADE_DATE_BAKFROM rc_tradeflow_details_napr -- 交易流水表WHERE OURS_ACCOUNT_NUMBER = '11111.com' AND ATTRIBUTE4 IS NULLORDER BY TRUNC(TRADE_DATE_BAK); cx_date DATE;    SUM_FUNDSFLOWCODE VARCHAR2(4000);temp VARCHAR2(4000); commit_counter NUMBER := 0; 
BEGINFOR rec IN cur_data LOOPBEGIN -- 找出與當前日期相同的日期SELECT TRUNC(d.postdatetime) INTO cx_dateFROM rc_fundflow_details_napr d -- 資金流水表WHERE 1=1AND d.MONEY_WAY ='充值'AND d.OURS_ACCOUNT_NUMBER in ('22222','33333','44444')AND d.CUSTOMER_ACCOUNT_NAME_ORIGIN = '支付寶(中國)網絡技術有限公司'AND d.CUSTOMER_ACCOUNT_NUMBER = '88888'-- AND TRUNC(TRADE_DATE_BAK) = rec.TRADE_DATE_BAK AND d.postdatetime >= rec.TRADE_DATE_BAK -- 優化為范圍查詢AND d.postdatetime < rec.TRADE_DATE_BAK + 1AND ROWNUM = 1;EXCEPTIONWHEN NO_DATA_FOUND THEN cx_date := NULL;END;-- 找出比當前日期小的最大日期IF cx_date IS NULL THENSELECT MAX(TRUNC(d.postdatetime)) INTO cx_dateFROM rc_fundflow_details_napr d -- 資金流水表WHERE 1=1AND d.MONEY_WAY ='充值'AND d.OURS_ACCOUNT_NUMBER in ('22222','33333','44444')AND d.CUSTOMER_ACCOUNT_NAME_ORIGIN = '支付寶(中國)網絡技術有限公司'AND d.CUSTOMER_ACCOUNT_NUMBER = '88888'AND d.postdatetime < rec.TRADE_DATE_BAK + INTERVAL '1' DAY;END IF;-- 找出比當前日期大的最小日期IF cx_date IS NULL THEN SELECT MIN(TRUNC(d.postdatetime)) INTO cx_dateFROM rc_fundflow_details_napr d -- 資金流水表WHERE 1=1AND d.MONEY_WAY ='充值'AND d.OURS_ACCOUNT_NUMBER in ('22222','33333','44444')AND d.CUSTOMER_ACCOUNT_NAME_ORIGIN = '支付寶(中國)網絡技術有限公司'AND d.CUSTOMER_ACCOUNT_NUMBER = '88888'AND d.postdatetime > rec.TRADE_DATE_BAK;END IF;-- 拼接這些日期的交易流水編號SELECT (RTRIM(EXTRACT(XMLAGG(XMLELEMENT(e, FUNDSFLOWCODE, ';') ORDER BY FUNDSFLOWCODE),'/E/text()').GETCLOBVAL(),';')) INTO SUM_FUNDSFLOWCODEFROM(SELECTFUNDFLOW_DETAILS_ID AS FUNDSFLOWCODEFROM rc_fundflow_details_napr d -- 資金流水表WHERE 1=1AND d.MONEY_WAY ='充值'AND d.OURS_ACCOUNT_NUMBER in ('22222','33333','44444')AND d.CUSTOMER_ACCOUNT_NAME_ORIGIN = '支付寶(中國)網絡技術有限公司'AND d.CUSTOMER_ACCOUNT_NUMBER = '88888'AND d.postdatetime >= cx_date AND d.postdatetime < cx_date +1);-- 更新交易流水表的本天的所有數據UPDATE rc_tradeflow_details_naprSET ATTRIBUTE4 = SUM_FUNDSFLOWCODEWHERE 1=1AND OURS_ACCOUNT_NUMBER = '11111.com' AND ATTRIBUTE4 IS NULLAND TRADE_DATE_BAK >= rec.TRADE_DATE_BAK AND TRADE_DATE_BAK < rec.TRADE_DATE_BAK+1;-- 增加計數器commit_counter := commit_counter + 1;-- 每處理一定數量的記錄后提交一次事務IF commit_counter >= 50 THEN COMMIT;commit_counter := 0; -- 重置計數器END IF;END LOOP;COMMIT;
END;

場景4多對多匹配

現有一批數據,要求交易表按照賬戶,日期進行分組匯總得到匯總金額
資金表按照戶名,日期進行分組得到匯總金額
按照日期,賬戶,匯總金額進行匹配,將交易表該組的所有憑證號和期間拼接帶入資金表該組的每一條數據
將資金表該組的所有URID拼接帶入交易表該組的每一條數據。完成所有這樣的組的匹配。

DECLARECURSOR data_cur IS(SELECTtransaction_date AS mats_1FROM(SELECTa.BUSI_DATE AS transaction_date,sum(CASE WHEN a.ENTERED_DR <> 0 THEN a.ENTERED_DR ELSE -a.ENTERED_CR end) AS jy_moneyFROM rc_bank_transactions aWHEREa.bankaccno_sid = '111111111111'GROUP BY a.BUSI_DATE) jyINNER JOIN (SELECTtrunc(b.postdatetime) AS postdatetime,sum(b.amount) AS zj_moneyFROM issue202412_recon_zjlsb bWHEREb.wf_account ='111111111111'AND b.企業賬憑證號 IS NULLGROUP BY trunc(b.postdatetime)) zjON TRUNC(jy.transaction_date) = zj.postdatetime AND jy.jy_money = zj.zj_money);mats_1 date;a_vouchers varchar2(4000);a_periods varchar2(4000);b_urids varchar2(4000);
BEGINFOR res IN data_cur LOOPmats_1 := res.mats_1;SELECT EXTRACT(XMLAGG(XMLELEMENT(e, pz, ';') ORDER BY pz),'/E/text()').GETCLOBVAL() INTO a_vouchersFROM (SELECT DISTINCT a.DOC_SEQUENCE_VALUE as pzFROM rc_bank_transactions a WHERE TRUNC(a.BUSI_DATE) = mats_1 AND a.bankaccno_sid = '111111111111');SELECT EXTRACT(XMLAGG(XMLELEMENT(e, qj, ';') ORDER BY qj),'/E/text()').GETCLOBVAL() INTO a_periodsFROM (SELECT DISTINCT a.FIN_PERIOD_NAME as qjFROM rc_bank_transactions a WHERE TRUNC(a.BUSI_DATE) = mats_1AND a.bankaccno_sid = '111111111111');	SELECT EXTRACT(XMLAGG(XMLELEMENT(e,urid, ';') ORDER BY urid),'/E/text()').GETCLOBVAL() INTO b_uridsFROM (SELECT DISTINCT b.urid as uridFROM issue202412_recon_zjlsb bWHERE trunc(b.postdatetime) = mats_1 AND b.wf_account = '111111111111');		UPDATE rc_bank_transactions a SET a.urid = b_uridsWHERE TRUNC(a.BUSI_DATE) = mats_1AND a.bankaccno_sid = '111111111111';UPDATE issue202412_recon_zjlsb b SET b.企業賬憑證號 = a_vouchers,b.企業賬期間 = a_periodsWHERE trunc(b.postdatetime) = mats_1 AND b.wf_account = '111111111111';END LOOP;COMMIT;
END;

場景5一對一匹配

現有一批數據,企業表和交易表要求按照賬戶,投保單,金額,日期匹配,將企業表的憑證號和期間帶入交易表。

DECLARE  
CURSOR c_update IS  SELECT a.ROWID AS row_id, b.DOC_SEQUENCE_VALUE, b.PERIOD_NAME  FROM rc_bank_transactions_202501 a,rc_fin_transactions_202501 b WHERE 1=1AND a.bankaccno_sid = b.bankaccno_sid AND a.REF_NUMBER = b.REF_NUMBERAND (CASE WHEN a.ENTERED_DR <> 0 THEN a.ENTERED_DR ELSE -a.ENTERED_CR end) = (CASE WHEN b.ENTERED_DR <> 0 THEN b.ENTERED_DR ELSE -b.ENTERED_CR end)    AND TO_CHAR(a.BUSI_DATE, 'YYYY-MM') = TO_CHAR(b.DEFAULT_EFFECTIVE_DATE, 'YYYY-MM')AND a.DOC_SEQUENCE_VALUE IS NULL;
BEGIN  FOR rec IN c_update LOOP  UPDATE rc_bank_transactions_202501 SET DOC_SEQUENCE_VALUE = rec.DOC_SEQUENCE_VALUE,  FIN_PERIOD_NAME = rec.PERIOD_NAME  WHERE ROWID = rec.row_id;  END LOOP;  COMMIT;  
END;  

場景6 一對多匹配

現有一批數據要求交易數據按照賬戶,批次號,日期進行分組匯總得到匯總金額與資金表的賬戶,日期,金額進行匹配,
要求將交易表的拼接后的憑證號和期間帶入與之匹配的資金表的數據中,同時將資金表的FUNDSFLOWCODE帶入與之匹配的所以交易表的數據。

beginFOR s in (SELECTll.reqbatchno,ll.transaction_date,ss.FUNDSFLOWCODEFROM(SELECTa.reqbatchno,a.PAYSENTDATE AS transaction_date,sum(a.PAYMONEY) AS jyamountFROMissue202501_rc_batch_jylsb aWHEREa.wf_ACCOUNT = '1111111111111111111111'GROUP BYa.reqbatchno,a.PAYSENTDATE) llINNER JOIN (SELECTd.postdatetime AS postdatetime,d.amount,d.FUNDSFLOWCODEFROMissue202501_recon_zjlsb dWHEREd.wf_account = '1111111111111111111111') ss ON TRUNC(ss.postdatetime) = TRUNC(ll.transaction_date) AND ss.amount = ll.jyamount) LOOPupdate issue202501_rc_batch_jylsb
set URID = s.FUNDSFLOWCODE,資金表規則名稱 = '11111更新規則1:我方賬號+交易日期+單筆金額'
where 1=1
AND wf_ACCOUNT = '1111111111111111111111'
AND reqbatchno = s.reqbatchno
AND PAYSENTDATE = s.transaction_date
;UPDATE issue202501_recon_zjlsb e
SET e.規則名稱= '11111更新規則1:批次號+交易提交日期+匯總金額',e.企業賬憑證號 = (SELECT RTRIM(XMLAGG(XMLELEMENT(x, DOC_SEQUENCE_VALUE, ';').EXTRACT('//text()') ORDER BY DOC_SEQUENCE_VALUE).GetClobVal(), ';')FROM (SELECT DISTINCT DOC_SEQUENCE_VALUEFROM issue202501_rc_batch_jylsbWHERE URID = s.FUNDSFLOWCODE) sub),e.企業賬期間 = (SELECT RTRIM(XMLAGG(XMLELEMENT(x,FIN_PERIOD_NAME, ';').EXTRACT('//text()') ORDER BY FIN_PERIOD_NAME).GetClobVal(), ';')FROM(SELECT DISTINCT FIN_PERIOD_NAMEFROM issue202501_rc_batch_jylsbWHERE URID = s.FUNDSFLOWCODE) sua)
WHERE e.FUNDSFLOWCODE = s.FUNDSFLOWCODE;end loop;commit; -- 提交所有數據
end;

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

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

相關文章

QML FontDialog:使用FontDialog實現字體選擇功能

目錄 引言相關閱讀FontDialog基本介紹字體屬性 實例演示項目結構代碼實現Main.qmlmain.cpp 代碼解析運行效果 總結 引言 在桌面應用程序開發中&#xff0c;字體選擇是一個常見的需求。Qt Quick提供了FontDialog組件來實現這一功能。本文將介紹如何在Qt Quick應用程序中使用Fon…

MCP(3):在CherryStudio中使用MCPServer

上一文章講述了如何新建一個MCP Server&#xff0c;并在MCP Inspector完成測試。本文講述如何在CherryStudio中進行測試。 Cherry Studio 是一款由 CherryHQ 開發的多模型支持的 AI 桌面助手&#xff0c;兼容 Windows、Linux 和 macOS 系統&#xff0c;旨在為用戶提供更便捷、…

面試題-鏈表(2)

1.合并兩個有序鏈表&#xff1a; 21. 合并兩個有序鏈表 - 力扣&#xff08;LeetCode&#xff09; public ListNode mergeTwoLists(ListNode headA, ListNode headB){ListNode newheadnew ListNode(-1);ListNode curnewhead;while(headA!null&&headB!null){if(headA.va…

微軟Entra新安全功能引發大規模賬戶鎖定事件

誤報觸發大規模鎖定 多家機構的Windows管理員報告稱&#xff0c;微軟Entra ID新推出的"MACE"&#xff08;泄露憑證檢測應用&#xff09;功能在部署過程中產生大量誤報&#xff0c;導致用戶賬戶被大規模鎖定。這些警報和鎖定始于昨夜&#xff0c;部分管理員認為屬于誤…

【MATLAB第117期】#源碼分享 | 基于MATLAB的SSM狀態空間模型多元時間序列預測方法(多輸入單輸出)

【MATLAB第117期】#源碼分享 | 基于MATLAB的SSM狀態空間模型多元時間序列預測方法&#xff08;多輸入單輸出&#xff09; 引言 本文使用狀態空間模型實現失業率遞歸預測&#xff0c;狀態空間模型&#xff08;State Space Model, SSM&#xff09;是一種用于描述動態系統行為的…

谷歌瀏覽器搜索后的頁面總是覆蓋當前頁面

最近將搜索引擎換為谷歌后&#xff0c;發現&#xff0c;每次搜索完的結果頁面總是覆蓋當前頁面&#xff0c;非常不方便&#xff0c;在瀏覽器設置中又找不到類似設置的選項&#xff0c;然后終于在一個博主“如何設置使谷歌瀏覽器打開鏈接自動跳轉到新標簽頁而不是覆蓋當前頁面?…

記錄學習的第三十天

今天終于又開始寫博客了。 還是滑動窗口問題&#xff0c;這段時間不出意外都是這了 上面的思路是我自己做的&#xff0c;但是不知道為什么不行&#xff0c;有沒有大佬能指點一下我。 接下來這道題是進階的。不過我之前的基礎都做的很艱難&#xff0c;道阻且長啊。

QTextDocument 入門

一、QTextDocument QTextDocument 是 Qt 中用于處理富文本文檔的核心類&#xff0c;支持文本格式、圖片、表格等復雜內容。 1. QTextDocument 入門 1.1 基本概念 QTextDocument 是 Qt 中用于處理富文本內容的核心類&#xff0c;它提供了&#xff1a; 結構化文本存儲&#x…

WebRTC服務器Coturn服務器相關測試工具

1、概述 在安裝開源的webrtc服務器coturn服務器后&#xff0c;會附帶安裝coturn的相關工具&#xff0c;主要有以下幾種工具 2、turnadmin工具 說明&#xff1a;服務器命令行工具&#xff0c;提供添加用戶、添加管理員、生成TURN密鑰等功能&#xff0c;turnadmin -h查看詳細用…

如何創建Vue3工程

1.首先下載環境 &#xff08;默認下好了VS code&#xff09; Node.js: Node.js 中文網 — 下載 Node.js 選擇要下載的版本 檢查環境&#xff1a; 在命令行中輸入 node ,檢查版本號 2.創建工程 1.找到自己要創建工程的文件目錄&#xff0c;右鍵打開打開終端 在終端輸入創…

基于大模型的肛裂手術全流程預測與治療方案研究報告

目錄 一、引言 1.1 研究背景與意義 1.2 研究目標與創新點 1.3 研究方法與技術路線 二、肛裂概述與大模型技術原理 2.1 肛裂的醫學定義與分類 2.2 肛裂的發病機制與臨床癥狀 2.3 大模型技術簡介 三、大模型在肛裂術前預測的應用 3.1 術前風險因素分析與數據收集 3.2 …

【趣味小游戲】--掃雷游戲

目錄 一.test.c部分 二.game.h部分 三.game.c部分 前言:前面學習了數組和函數等c語言相關知識&#xff0c;這篇文章我們將通過這些知識分為三個文件來完成掃雷游戲&#xff1b; 1.test.c //文件中寫游戲的測試邏輯 2.game.c //文件中寫游戲中函數的實現等 3.game.h. //文件中寫…

【微服務】SpringBoot制作Docker鏡像接入SkyWalking詳解

目錄 一、前言 二、SkyWalking介紹 2.1 SkyWalking是什么 2.2 SkyWalking核心功能 2.3 SkyWalking整體架構 2.4 SkyWalking主要工作流程 三、前置準備 3.1 搭建SkyWalking服務 3.1.1 下載安裝包 3.1.2 上傳服務器目錄 2.1.3 數據庫持久化配置說明 3.1.4 啟動skywalk…

從零開始構建微博爬蟲與數據分析系統

從零開始構建微博爬蟲與數據分析系統 引言 社交媒體平臺蘊含著海量的信息和數據&#xff0c;通過對這些數據的收集和分析&#xff0c;我們可以挖掘出有價值的見解。本文將詳細介紹如何構建一個完整的微博爬蟲和數據分析系統&#xff0c;從數據爬取、清洗、到多維度分析與可視…

深入探索RAG:用LlamaIndex為大語言模型擴展知識,實現智能檢索增強生成

大型語言模型&#xff08;LLM&#xff09;&#xff0c;如ChatGPT和Llama&#xff0c;在回答問題方面表現出色&#xff0c;但它們的知識僅限于訓練時所獲取的信息。它們無法訪問私有數據&#xff0c;也無法在訓練截止日期之后學習新知識。那么&#xff0c;核心問題就是……我們如…

【延遲雙刪】簡單解析

使用場景&#xff1a;【高并發】情況下的做【更新操作】 什么是延遲雙刪 首次刪除&#xff1a;當需要更新某個數據項時&#xff0c;首先刪除緩存中的該項。 更新數據庫&#xff1a;接著&#xff0c;更新數據庫中的該項。 短暫延遲&#xff1a;然后等待一段很短的時間&#xff…

解決Windows安全中心顯示空白頁面

1、電腦重裝系統后&#xff0c;發現原本一些軟件打不開了&#xff0c;電腦莫名認為有病毒&#xff0c;自動刪除插件。附圖。 2、第一反應是電腦防火墻的原因&#xff0c;默認威脅防護識別到了病毒軟件&#xff0c;自動刪除。在開始屏幕搜Windows安全中心&#xff0c;打開之后發…

【回眸】error: failed to compile `xxxxxx`重裝rust環境

在ubuntu上安裝軟件報錯 error: failed to compile cxx2flow v0.6.2 Caused by: package cargo-platform v0.1.9 cannot be built because it requires rustc 1.78 or newer, while the currently active rustc version is 1.75.0 Try re-running cargo install with --lo…

算法—冒泡排序—js(教學示例、小數據)

冒泡排序原理 冒泡排序是一種簡單的排序算法&#xff0c;通過重復遍歷數組&#xff0c;比較相鄰元素并交換位置&#xff0c;使較大的元素逐漸“浮”到數組末尾。 特點 時間復雜度&#xff1a;平均 O(n)&#xff0c;最優&#xff08;已有序時&#xff09;O(n) 空間復雜度&#…

linux sysfs的使用

在Linux內核驅動開發中&#xff0c;device_create_file 和 device_remove_file 用于動態創建/刪除設備的 sysfs 屬性文件&#xff0c;常用于暴露設備信息或控制參數。以下是完整示例及詳細說明&#xff1a; 1. 頭文件引入 #include <linux/module.h> #include <linux/…