主頁 > 知識庫 > python 實現(xiàn)mysql自動增刪分區(qū)的方法

python 實現(xiàn)mysql自動增刪分區(qū)的方法

熱門標簽:400電話申請服務商選什么 在哪里辦理400電話號碼 西藏智能外呼系統(tǒng)五星服務 原裝電話機器人 工廠智能電話機器人 平頂山外呼系統(tǒng)免費 千陽自動外呼系統(tǒng) 江蘇客服外呼系統(tǒng)廠家 清遠360地圖標注方法

連接mysql

#!/usr/bin/python
#-*- coding:utf-8 -*-

import time
import pymysql

class connect_mysql(object):
  def __init__(self, host, dbname):
    self.mysql_config = {
      'host': host,
      'port': 33071,
      'user': 'sysbench',
      'passwd': '970125',
      'db': dbname,
      'charset': 'utf8mb4',
    }
    self.dbname = dbname


  def select_db(self, sql):
    mysql_conn = pymysql.connect(**self.mysql_config)
    try:
      query = "%s" %(sql)
      cur = mysql_conn.cursor()
      cur.execute(query)
      results = cur.fetchall()
      cur.close()
      mysql_conn.close()
      return results
    except Exception as err:
      print(err)

  def excute_db(self, sql):
    mysql_conn = pymysql.connect(**self.mysql_config)
    try:
      cur = mysql_conn.cursor()
      cur.execute(sql)
      mysql_conn.commit()
      cur.close()
      mysql_conn.close()
      return 0
    except Exception as err:
      mysql_conn.rollback()
      print(err)

增刪分區(qū)

#!/usr/bin/python
#-*- coding:utf-8 -*-
import sys
import pymysql
import importlib
import logging
from datetime import datetime, timedelta
from dateutil.relativedelta import relativedelta
from connect_db_forbatch import connect_mysql

def incr_partition():
  print("新增分區(qū)...")
  max_partition_sql = "SELECT REPLACE(partition_name,'p','') FROM INFORMATION_SCHEMA.PARTITIONS WHERE TABLE_SCHEMA='%s' and table_name='%s' ORDER BY partition_ordinal_position DESC LIMIT 1;" %(db_name,table_name)
#  print(max_partition_sql)
  max_partition = connect_mysql(host,db_name).select_db(max_partition_sql)
  max_date = str(max_partition[0][0])
  max_partition_name = (datetime.strptime(max_date, "%Y%m%d") + relativedelta(days=1)).strftime("%Y%m%d")
  max_partition_value = (datetime.strptime(max_date, "%Y%m%d") + relativedelta(days=2)).strftime("'%Y-%m-%d'")
  alter_max_partition_sql = "ALTER TABLE %s.%s ADD PARTITION (PARTITION p%s VALUES LESS THAN (to_days(%s)) ENGINE = InnoDB);" %(db_name,table_name,max_partition_name,max_partition_value)
  print(alter_max_partition_sql)
  connect_mysql(host,db_name).excute_db(alter_max_partition_sql)

def del_partition():
  print("刪除分區(qū)...")
  min_partition_sql = "SELECT REPLACE(partition_name,'p','') FROM INFORMATION_SCHEMA.PARTITIONS WHERE TABLE_SCHEMA='sbtest' and table_name='t1' ORDER BY partition_ordinal_position LIMIT 1;"
#  print(min_partition_sql)
  min_partition = connect_mysql(host,db_name).select_db(min_partition_sql)
  min_date = str(min_partition[0][0])
  min_partition_name = (datetime.strptime(min_date, "%Y%m%d") + relativedelta(days=0)).strftime("%Y%m%d")
  alter_min_partition_sql = "ALTER TABLE %s.%s DROP PARTITION p%s;" %(db_name,table_name,min_partition_name)
  print(alter_min_partition_sql)
  connect_mysql(host,db_name).excute_db(alter_min_partition_sql)

if __name__ == "__main__":
  host = sys.argv[1]
  db_name = sys.argv[2]
  table_name = sys.argv[3]
  incr_partition()
  del_partition()

到此這篇關于python 實現(xiàn)mysql自動增刪分區(qū)的方法的文章就介紹到這了,更多相關python mysql自動增刪分區(qū)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • MySQL分庫分表與分區(qū)的入門指南
  • MySql分表、分庫、分片和分區(qū)知識深入詳解
  • MySQL學習記錄之KEY分區(qū)引發(fā)的血案
  • Mysql臨時表及分區(qū)表區(qū)別詳解
  • 詳解MySQL分區(qū)表
  • MySQL最佳實踐之分區(qū)表基本類型
  • MySQL分區(qū)表的最佳實踐指南
  • MySql分表、分庫、分片和分區(qū)知識點介紹
  • MySQL分表和分區(qū)的具體實現(xiàn)方法
  • MySQL分區(qū)表的正確使用方法
  • MySQL高級特性——數(shù)據(jù)表分區(qū)的概念及機制詳解

標簽:股票 天水 西安 隨州 錦州 日照 安慶 白城

巨人網(wǎng)絡通訊聲明:本文標題《python 實現(xiàn)mysql自動增刪分區(qū)的方法》,本文關鍵詞  python,實現(xiàn),mysql,自動,增刪,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python 實現(xiàn)mysql自動增刪分區(qū)的方法》相關的同類信息!
  • 本頁收集關于python 實現(xiàn)mysql自動增刪分區(qū)的方法的相關信息資訊供網(wǎng)民參考!
  • 推薦文章