亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 如何為PostgreSQL的表自動添加分區

如何為PostgreSQL的表自動添加分區

熱門標簽:漯河外呼電話系統 打電話智能電銷機器人授權 海豐有多少商家沒有地圖標注 美容工作室地圖標注 辦公外呼電話系統 合肥公司外呼系統運營商 外呼調研系統 重慶自動外呼系統定制 地圖標注和圖片名稱的區別

PostgreSQL 引進“分區”表特性,解放了之前采用“表繼承”+ “觸發器”來實現分區表的繁瑣、低效。而添加分區,都是手動執行 SQL。

演示目的:利用 python 來為 PostgreSQL 的表自動添加分區。

python版本: python3+

pip3 install psycopg2

一、配置數據源

database.ini 文件:記錄數據庫連接參數

[adsas]
host=192.168.1.201
database=adsas
user=adsas
password=adsas123
port=5432
[test]
host=192.168.1.202
database=adsas
user=adsas
password=adsas123
port=5432

二、config 腳本

config.py 文件:下面的config() 函數讀取database.ini文件并返回連接參數。config() 函數位于config.py文件中

#!/usr/bin/python3
from configparser import ConfigParser
 
def config(section ,filename='database.ini'):
  # create a parser
  parser = ConfigParser()
  # read config file
  parser.read(filename)
 
  # get section, default to postgresql
  db = {}
  if parser.has_section(section):
    params = parser.items(section)
    for param in params:
      db[param[0]] = param[1]
  else:
    raise Exception('Section {0} not found in the {1} file'.format(section, filename))
 
  return db

三、創建子表腳本

pg_add_partition_table.py 文件:其中 create_table函數是創建子表SQL。其中參數

參數名 含義
db 指向數據庫
table 主表
sub_table 正要新建的子表名
start_date 范圍分界開始值
end_date 范圍分界結束值

#!/usr/bin/python3
import psycopg2
from config import config
# example: create table tbl_game_android_step_log_2021_07 PARTITION OF tbl_game_android_step_log FOR VALUES FROM ('2021-07-01') TO ('2021-08-01');
def create_table(db, table, sub_table, start_date, end_date):
  """ create subtable in the PostgreSQL database"""
  command = "create table {0} PARTITION OF {1} FOR VALUES FROM ('{2[0]}') TO ('{2[1]}');".format(sub_table, table, (start_date, end_date)) 
  conn = None
  try:
    # read the connection parameters
    params = config(section = db)
    # connect to the PostgreSQL server
    conn = psycopg2.connect(**params)
    cur = conn.cursor()
    # create table one by one
    cur.execute(command)
    # close communication with the PostgreSQL database server
    cur.close()
    # commit the changes
    conn.commit()
  except (Exception, psycopg2.DatabaseError) as error:
    print(error)
  finally:
    if conn is not None:
      conn.close()

四、執行文件main.py

main.py:主文件;通過執行main生成分區表。

示例:

#!/usr/bin/python3
import datetime
from datetime import date
from dateutil.relativedelta import *
from pg_add_partition_table import create_table
# Get the 1st day of the next month
def get_next_month_first_day(d):
  return date(d.year + (d.month == 12), d.month == 12 or d.month + 1 , 1)
  
def create_sub_table(db, table):
  # Get current date
  d1 = date.today()
  # Get next month's date
  d2 = d1 + relativedelta(months=+1)
  # Get the 1st day of the next month;As the starting value of the partitioned table
  start_date = get_next_month_first_day(d1)
  # Gets the 1st of the next two months as the end value of the partitioned table
  end_date = get_next_month_first_day(d2)
  # get sub table name
  getmonth = datetime.datetime.strftime(d2, '%Y_%m')
  sub_table = table + '_' + getmonth
  create_table(db, table, sub_table, start_date, end_date)
	
if __name__ == '__main__':
  create_sub_table('test', 'tbl_game_android_step_log');

上面示例單獨為表tbl_game_android_step_log;創建分區;若多個表;用for語句處理

 # 多表操作
  for table in ['tbl_game_android_step_log', 'tbl_game_android_game_log','tbl_game_android_pay_log']:
    create_sub_table('test', table);

]

演示之前:

adsas=> select * from pg_partition_tree('tbl_game_android_step_log');
        relid        |    parentrelid    | isleaf | level 
-----------------------------------+---------------------------+--------+-------
 tbl_game_android_step_log     |              | f   |   0
 tbl_game_android_step_log_2020_12 | tbl_game_android_step_log | t   |   1
(2 rows)

演示之后:

adsas=> select * from pg_partition_tree('tbl_game_android_step_log');
        relid        |    parentrelid    | isleaf | level 
-----------------------------------+---------------------------+--------+-------
 tbl_game_android_step_log     |              | f   |   0
 tbl_game_android_step_log_2020_12 | tbl_game_android_step_log | t   |   1
 tbl_game_android_step_log_2021_01 | tbl_game_android_step_log | t   |   1
Partition key: RANGE (visit_time)
Partitions: tbl_game_android_step_log_2020_12 FOR VALUES FROM ('2020-12-01 00:00:00') TO ('2021-01-01 00:00:00'),
      tbl_game_android_step_log_2021_01 FOR VALUES FROM ('2021-01-01 00:00:00') TO ('2021-02-01 00:00:00')

五、加入定時任務

到此這篇關于如何為PostgreSQL的表自動添加分區的文章就介紹到這了,更多相關PostgreSQL的表添加分區內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • PostgreSQL LIST、RANGE 表分區的實現方案
  • PostgreSQL 創建表分區
  • 淺析postgresql 數據庫 TimescaleDB 修改分區時間范圍
  • 利用python為PostgreSQL的表自動添加分區
  • 淺談PostgreSQL 11 新特性之默認分區
  • PostgreSQL之分區表(partitioning)
  • PostgreSQL分區表(partitioning)應用實例詳解
  • PostgreSQL教程(三):表的繼承和分區表詳解
  • 淺談PostgreSQL表分區的三種方式

標簽:晉城 衡陽 株洲 錦州 烏海 珠海 來賓 蚌埠

巨人網絡通訊聲明:本文標題《如何為PostgreSQL的表自動添加分區》,本文關鍵詞  如,何為,PostgreSQL,的,表,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何為PostgreSQL的表自動添加分區》相關的同類信息!
  • 本頁收集關于如何為PostgreSQL的表自動添加分區的相關信息資訊供網民參考!
  • 推薦文章
    国产91丝袜高跟系列| 日韩专区一区| 亚欧成人乱码一区二区| 国产精品自拍在线| 欧美一级视| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 欧美大片a一级毛片视频| 亚洲精品久久玖玖玖玖| 四虎影视库| 日韩中文字幕一区| 麻豆网站在线看| 一级毛片看真人在线视频| 色综合久久天天综合绕观看| 免费的黄色小视频| 久久精品成人一区二区三区| 久久精品成人一区二区三区| 美女免费精品高清毛片在线视| 亚洲 男人 天堂| 国产a视频| 国产一区二区精品久久| 成人免费观看视频| 二级特黄绝大片免费视频大片| 久久久久久久免费视频| 欧美一级视频免费| 麻豆午夜视频| 国产视频一区二区在线播放| 精品视频在线观看一区二区三区| 九九九国产| 成人免费一级毛片在线播放视频| 欧美另类videosbestsex视频| 日本特黄一级| 国产一区二区精品在线观看| 亚久久伊人精品青青草原2020| 欧美大片a一级毛片视频| 精品视频一区二区三区| 欧美a级v片不卡在线观看| 国产麻豆精品视频| 午夜激情视频在线观看| 国产不卡高清| 国产高清在线精品一区二区| 国产91丝袜高跟系列| 天堂网中文在线| 国产一级强片在线观看| 国产一区二区精品| 色综合久久天天综合绕观看| 国产成a人片在线观看视频| 久久久久久久免费视频| 国产欧美精品午夜在线播放| 精品视频在线观看视频免费视频| 国产高清在线精品一区二区| 久久99爰这里有精品国产| 亚洲女初尝黑人巨高清在线观看| 高清一级做a爱过程不卡视频| 麻豆午夜视频| 精品在线观看一区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 欧美爱色| 国产麻豆精品hdvideoss| 日韩免费在线视频| 一级女性全黄生活片免费| 精品在线观看一区| 你懂的国产精品| 成人免费观看的视频黄页| 国产麻豆精品hdvideoss| 一级片片| 国产国产人免费视频成69堂| 国产伦精品一区二区三区无广告 | 国产精品自拍在线| 青青久久国产成人免费网站| 九九免费精品视频| 日韩免费在线视频| 精品视频在线观看一区二区三区| 中文字幕97| 国产不卡在线观看| 国产成人欧美一区二区三区的| 香蕉视频久久| 中文字幕97| 九九免费精品视频| 免费国产一级特黄aa大片在线| 国产视频一区二区在线播放| 国产伦精品一区三区视频| 天天做日日干| 成人免费网站视频ww| 久久99爰这里有精品国产| 一本高清在线| 成人影院一区二区三区| 日本伦理黄色大片在线观看网站| 免费毛片播放| 亚洲爆爽| 色综合久久久久综合体桃花网| 香蕉视频久久| 成人在免费观看视频国产| 黄色短视频网站| 亚洲精品影院一区二区| 久久国产一区二区| 91麻豆高清国产在线播放| 欧美大片毛片aaa免费看| 成人高清视频免费观看| 日本在线www| 免费一级片在线观看| 日日夜夜婷婷| 日本免费看视频| 99热精品一区| 天天做日日干| 精品视频免费在线| 国产伦久视频免费观看视频| 欧美1区| 精品视频免费观看| 91麻豆精品国产片在线观看| 国产视频一区二区在线播放| 久久久成人影院| 你懂的国产精品| 青青久久网| 黄视频网站在线免费观看| 国产一区免费在线观看| 国产伦久视频免费观看视频| 日韩中文字幕在线观看视频| 国产a一级| 国产一区二区精品| 天堂网中文在线| 国产麻豆精品免费密入口| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日韩在线观看视频网站| 欧美大片毛片aaa免费看| 午夜精品国产自在现线拍| 99热精品一区| 精品视频在线观看免费| 四虎影视库| 一级毛片视频免费| 国产精品自拍在线| 91麻豆tv| 成人影视在线观看| 亚洲天堂免费观看| 日本免费看视频| 美女免费毛片| 国产国语在线播放视频| 亚洲天堂免费观看| a级精品九九九大片免费看| 美国一区二区三区| 99久久网站| 99热精品一区| 成人免费观看视频| 国产原创中文字幕| 国产成人精品一区二区视频| a级毛片免费全部播放| 国产成人精品一区二区视频| 午夜久久网| 国产福利免费观看| 美国一区二区三区| 在线观看成人网| 精品国产一级毛片| a级精品九九九大片免费看| 久久精品道一区二区三区| 一级女性大黄生活片免费| 欧美a级v片不卡在线观看| 麻豆午夜视频| 国产精品123| 91麻豆精品国产综合久久久| 国产精品123| 精品在线观看一区| 国产91精品一区| 九九免费精品视频| 午夜在线观看视频免费 成人| 日本伦理黄色大片在线观看网站| 成人免费网站视频ww| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产成人精品综合| 欧美一级视频免费| 亚洲 男人 天堂| 国产国语在线播放视频| 高清一级做a爱过程不卡视频| 国产视频一区二区在线播放| 国产伦精品一区三区视频| 99久久网站| 亚欧成人乱码一区二区| 天堂网中文在线| 国产不卡在线看| 可以免费看污视频的网站| 免费毛片播放| 午夜在线亚洲男人午在线| 日本免费乱人伦在线观看| 国产网站在线| 九九久久99| 九九免费精品视频| 成人a级高清视频在线观看| 亚洲 国产精品 日韩| 青青青草影院| 你懂的国产精品| 免费的黄色小视频| 成人免费一级毛片在线播放视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产不卡高清| 香蕉视频久久| 免费的黄色小视频| 国产国语在线播放视频| 欧美一级视| 深夜做爰性大片中文| 欧美大片毛片aaa免费看| 精品国产香蕉在线播出| 亚洲精品中文一区不卡|