国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:96日期:2022-06-23 15:43:07

連接mysql

#!/usr/bin/python#-*- coding:utf-8 -*-import timeimport pymysqlclass 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 sysimport pymysqlimport importlibimport loggingfrom datetime import datetime, timedeltafrom dateutil.relativedelta import relativedeltafrom connect_db_forbatch import connect_mysqldef 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()

到此這篇關(guān)于python 實(shí)現(xiàn)mysql自動(dòng)增刪分區(qū)的方法的文章就介紹到這了,更多相關(guān)python mysql自動(dòng)增刪分區(qū)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 新田县| 沽源县| 江孜县| 平邑县| 孟津县| 翼城县| 翁牛特旗| 苗栗市| 洞口县| 莱芜市| 嵊州市| 高碑店市| 垣曲县| 桃江县| 陆良县| 宁阳县| 镇康县| 胶南市| 南投市| 呼玛县| 莱西市| 罗田县| 南华县| 辛集市| 克东县| 南昌市| 三江| 西乌| 横峰县| 阿克陶县| 仪征市| 历史| 佛山市| 阜城县| 葫芦岛市| 扶风县| 辉南县| 周宁县| 江山市| 南安市| 永泰县|