Spring Boot中如何查詢PGSQL分表后的數據

數據庫用的pgsql,在表數據超過100w條的時候執行定時任務進行了分表,分表后表名命名為原的表名后面拼接時間,如原表名是card_device_trajectory_info,分表后拼接時間后得到card_device_trajectory_info_20240503,然后分表后把原來的表重置為空。這樣就把100w條數據放到了card_device_trajectory_info_20240503里面,card_device_trajectory_info重置空,以此類推。但是我在java業務代碼中,我想查詢之前的那條數據就查不到了,要怎么關聯上之前分出去的表去查詢呢?

在這里插入圖片描述

首先,我們要獲取到表名,因為表名是不明確的,所以要通過模糊查詢的方式獲取表名

在這里插入圖片描述
可以用List<String>去存儲表明,然后獲取列表的大小去做一個循環,從每一張表中查詢,直到循環結束。但是這種方式極可能影響性能消耗,所以。。。

下面是代碼示例

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;public class Main {public static void main(String[] args) {String baseTableName = "card_device_trajectory_info"; // 基礎表名String url = "jdbc:postgresql://localhost:5432/your_database";String user = "your_username";String password = "your_password";try (Connection conn = DriverManager.getConnection(url, user, password);Statement stmt = conn.createStatement()) {String sql = "SELECT table_name FROM information_schema.tables WHERE table_name LIKE '" + baseTableName + "%'";ResultSet rs = stmt.executeQuery(sql);// 處理查詢結果,獲取所有分表名稱while (rs.next()) {String tableName = rs.getString("table_name");// 根據業務邏輯處理分表名稱,比如存入集合或者數組中}// 根據業務邏輯構建查詢語句來查詢特定的分表for (String tableName : yourTableCollection) { // 替換yourTableCollection為你保存分表名稱的集合或數組String querySql = "SELECT * FROM " + tableName + " WHERE your_condition_here";// 執行查詢操作并處理結果}} catch (SQLException e) {e.printStackTrace();}}
}

如果數據量很大且分表很多,那么逐個查詢并遍歷所有分表的方式可能會影響性能并消耗大量時間和資源。針對這種情況,可以考慮以下一些優化方案來減少性能消耗:

  • 分頁查詢:可以考慮對每張分表進行分頁查詢,以減少單次查詢返回的數據量,從而降低查詢的性能消耗。
  • 并發查詢:可以考慮使用多線程或異步方式,并發地查詢多張分表,以縮短整體查詢所需的時間。
  • 數據預處理:如果業務允許,可以考慮在數據寫入時進行預處理,將需要頻繁查詢的數據進行匯總或者合并存儲,以減少查詢時的分表數量和數據量。
  • 數據庫分區:考慮根據業務需求對數據庫進行分區,將數據分散存儲到不同的物理存儲中,從而減少單個查詢涉及的數據量。
  • 數據緩存:對查詢結果進行緩存,避免重復查詢相同的數據,提高查詢效率。

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

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

相關文章

ubuntu使用oh my zsh美化終端

ubuntu使用oh my zsh美化終端 文章目錄 ubuntu使用oh my zsh美化終端1. 安裝zsh和oh my zsh2. 修改zsh主題3. 安裝zsh插件4. 將.bashrc移植到.zshrcReference 1. 安裝zsh和oh my zsh 首先安裝zsh sudo apt install zsh然后查看本地有哪些shell可以使用 cat /etc/shells 將默…

使用nexus搭建的nodejs私庫,定期清理無用的npm組件,徹底釋放磁盤空間

一、背景 昨天我們整理了一篇關于docker私庫&#xff0c;如何定期清理以釋放磁盤空間的文章。 雖然也提及了npm前端應用的組件該如何定期清理的&#xff0c;本文是對它作一個補充說明。 前文也看到了&#xff0c;npm組件占用的blob空間為180多GB&#xff0c;急需清理。 二、…

Flutter 中的 MouseRegion 小部件:全面指南

Flutter 中的 MouseRegion 小部件&#xff1a;全面指南 在 Flutter 中&#xff0c;MouseRegion 是一個非常有用的小部件&#xff0c;它允許你為部件添加鼠標事件&#xff08;如點擊、懸停、離開等&#xff09;。這在開發需要處理鼠標交互的應用時尤為重要。本文將詳細介紹 Mou…

100個 Unity小游戲系列三 -Unity 抽獎游戲專題一 轉盤抽獎游戲

一 、效果展示 二、知識點 2.1 布局需要實現功能 1、轉動的根目錄為itemSpinRoot 2、創建對應的item 3、每個item轉動的角度 2.2 代碼 public class WheelDialog : UIBase{[SerializeField] Button btnClick;[SerializeField] Button btnClose;[SerializeField] Sprite[] ite…

微信小程序(路由傳參)

微信小程序的路由系統和其他Web應用類似&#xff0c;主要通過頁面路徑和URL參數進行頁面導航和數據傳遞。下面詳細介紹微信小程序路由的基本使用方法和相關技巧。 1. 基本頁面導航 1.1 配置頁面路徑 在微信小程序的 app.json 文件中&#xff0c;需要配置小程序的頁面路徑。這…

哪有異地組網的工具?

不同地區的電腦與電腦、設備與設備、電腦與設備之間的信息遠程通信&#xff0c;一直是企業和個人面臨的難題。通過使用天聯組網的解決方案&#xff0c;這個問題將迎刃而解。 天聯組網解決方案 天聯組網是一種可以實現不同地區之間電腦、設備及其之間的信息遠程通信的解決方案。…

Trie字符串統計-java

Trie&#xff0c;又稱前綴樹或字典樹&#xff0c;是一種有序樹&#xff0c;用于保存關聯數組&#xff0c;其中的鍵通常是字符串。 目錄 前言? 一、Trie字符串統計? 二、算法思路? 1.Trie樹定義&#x1f319; 2.變量解釋&#x1f319; 3.插入操作&#x1f319; 4.Trie樹查找操…

vim文本編輯器相關用法

1. 引言 Vim&#xff0c;一個功能強大的文本編輯器&#xff0c;它在程序員和系統管理員中廣受歡迎。Vim是Vi的增強版&#xff0c;提供了一系列高級功能&#xff0c;包括語法高亮、代碼補全、多窗口編輯等。 2. Vim的安裝 Vim的安裝過程在不同的Linux發行版中略有不同。以下是…

MapStruct高級用法

MapStruct高級用法 依賴注入&#xff08;Using dependency injection&#xff09; Mapper(componentModel SPRING) public interface SpringMapper {SpringMapper MAPPER Mappers.getMapper(SpringMapper.class);PersonDTO personDoToDTO(Person person); }public static fin…

【class18】人工智能初步----語音識別(4)

【class17】 上節課&#xff0c;我們學習了: 語音端點檢測的相關概念&#xff0c;并通過代碼切分和保存了音頻。 本節課&#xff0c;我們將學習這些知識點&#xff1a;1. 序列到序列模型2. 循環神經網絡3. 調用短語音識別接口 知其然&#xff0c;知其所以然 在調用語…

數組單調棧-901. 股票價格跨度、leetcode

單調棧作為一種數據結構在求解類遞增、遞減方面的題目中有較為廣泛的應用&#xff0c;在以往的leetcode中所見到的相關單調棧的題目均為單一元素&#xff0c;今天刷到901題目時&#xff0c;想到了將數組元素作為單調棧中元素的方法進行求解。 題目鏈接及描述 901. 股票價格跨…

【c++leetcode】69. Sqrt(x)

問題入口 二分搜索 最困難的是能否意識到用二分搜索法解題。 算術平方根的區間在[1, x] 。代碼如下&#xff1a; class Solution { public:int mySqrt(int x) {if (x 1 || x 0){return x;}int64_t start 1;int64_t end x;while (start < x){int64_t mid start (en…

開源模型應用落地-Gradio正確集成Fastapi-助力模型交互-實踐篇(二)

一、前言 Gradio提供了直觀的用戶界面,當與Fastapi結合后,用戶可以通過界面輕松地與模型進行交互,上傳數據、獲取推理結果等,使得交互性增強,提升了用戶體驗。 在開源大語言模型遍地開花的時代,正確的使用Gradio和Fastapi,通過兩者的集成,使得模型的部署和使用過程更加…

以果決其行,只為文化的傳承

從他們每一個人的身上&#xff0c;我們看到傳神的東西&#xff0c;就是他們都能用結果&#xff0c;去指引自己前進的方向&#xff0c;這正是我要解讀倪海廈老師的原因&#xff0c;看倪海廈2012年已經去世&#xff0c;到現在已經十幾年時間了&#xff0c;但是我們看現在自學中醫…

【Pandas】深入解析`pd.to_sql()`函數

【Pandas】深入解析pd.to_sql()函數 &#x1f308; 歡迎蒞臨我的個人主頁&#x1f448;這里是我深耕Python編程、機器學習和自然語言處理&#xff08;NLP&#xff09;領域&#xff0c;并樂于分享知識與經驗的小天地&#xff01;&#x1f387; &#x1f393; 博主簡介&#xff1…

2024年第六屆中青杯數學建模競賽淺析

獲取比賽資料&#xff0c;請關注gzh“小何數模”&#xff01; 本次中青杯數學建模的賽題已正式出爐&#xff0c;無論是賽題難度還是認可度&#xff0c;該比賽都是僅次于數模國賽的獨一檔&#xff0c;可以用于國賽前的練手訓練。考慮到大家解題實屬不易&#xff0c;為了幫助大家…

JavaSE:StringBuilder和StringBuffer類

1、引言 在上一篇文章中&#xff0c;我們理解了字符串的常用方法&#xff0c;細心的同學大概已經發現&#xff0c;不管是將字符串中的字符轉變為大寫或小寫&#xff0c;或是完成字符串的替換&#xff0c;又或是去除空白字符等等&#xff0c;只要涉及到字符串的修改&#xff0c…

【PB案例學習筆記】-10 進度條使用

寫在前面 這是PB案例學習筆記系列文章的第10篇&#xff0c;該系列文章適合具有一定PB基礎的讀者。 通過一個個由淺入深的編程實戰案例學習&#xff0c;提高編程技巧&#xff0c;以保證小伙伴們能應付公司的各種開發需求。 文章中設計到的源碼&#xff0c;小凡都上傳到了gite…

Java用反射reflect來實例化對象: class.getDeclaredConstructor().newInstance()

Java用反射reflect來實例化對象: class.getDeclaredConstructor().newInstance() 從java9開始, class.newInstance()已過時, 被加上Deprecated強烈反對注解 SuppressWarnings("removal")CallerSensitiveDeprecated(since"9")public T newInstance()throws …

防止自動化攻擊的最佳實踐

防止自動化攻擊的最佳實踐 在當今的網絡安全環境中&#xff0c;保護用戶賬戶免受自動化攻擊已成為每個網站和應用程序的重要任務。攻擊者可以利用多種不同類型的自動化攻擊來嘗試破壞用戶賬戶。本文將詳細介紹常見的攻擊類型及其防御機制&#xff0c;幫助您更好地保護用戶賬戶…