婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python 實現mysql自動增刪分區的方法

python 實現mysql自動增刪分區的方法

熱門標簽:400電話申請服務商選什么 在哪里辦理400電話號碼 西藏智能外呼系統五星服務 原裝電話機器人 工廠智能電話機器人 平頂山外呼系統免費 千陽自動外呼系統 江蘇客服外呼系統廠家 清遠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)

增刪分區

#!/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("新增分區...")
  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("刪除分區...")
  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 實現mysql自動增刪分區的方法的文章就介紹到這了,更多相關python mysql自動增刪分區內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

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

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

巨人網絡通訊聲明:本文標題《python 實現mysql自動增刪分區的方法》,本文關鍵詞  python,實現,mysql,自動,增刪,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python 實現mysql自動增刪分區的方法》相關的同類信息!
  • 本頁收集關于python 實現mysql自動增刪分區的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 杭锦后旗| 龙山县| 梁平县| 当雄县| 哈尔滨市| 泽州县| 株洲市| 长武县| 壤塘县| 察哈| 巨鹿县| 南开区| 湛江市| 连云港市| 高雄市| 丹阳市| 韶关市| 城口县| 搜索| 泗阳县| 龙门县| 天等县| 长寿区| 孟州市| 双峰县| 六安市| 江源县| 福安市| 沿河| 鲁甸县| 濮阳县| 仁怀市| 克东县| 涟水县| 新竹县| 囊谦县| 镇沅| 桑日县| 资中县| 昆明市| 布拖县|