佳木斯湛栽影视文化发展公司

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

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

熱門標簽:電話運營中心 硅谷的囚徒呼叫中心 Win7旗艦版 語音系統(tǒng) 呼叫中心市場需求 百度AI接口 企業(yè)做大做強 客戶服務

連接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ū)的概念及機制詳解

標簽:海南 崇左 喀什 長沙 濟南 山西 安康 山西

巨人網絡通訊聲明:本文標題《python 實現(xiàn)mysql自動增刪分區(qū)的方法》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    青浦区| 大田县| 昭通市| 诏安县| 佛冈县| 九台市| 绥滨县| 西藏| 南安市| 视频| 边坝县| 盘山县| 山丹县| 唐山市| 明溪县| 迭部县| 永登县| 库尔勒市| 余姚市| 本溪| 西丰县| 互助| 沧州市| 宝丰县| 台州市| 长沙县| 依兰县| 酉阳| 江陵县| 兴城市| 弥渡县| 蓬溪县| 武强县| 康定县| 女性| 梅州市| 阿拉善盟| 澄江县| 姚安县| 墨玉县| 酉阳|