python中查询数据库个数_【数据库】MySQL中数据库和表容量大小的查询方法以及Python实现...

import MySQLdb

# 连接管理

class Client():

def __init__(self, **kwargs):

try:

self.conn = MySQLdb.connect(host=kwargs.get('host'),

user=kwargs.get('user', 'root'),

password=kwargs.get('password'),

charset=kwargs.get('charset', 'utf8'),

use_unicode=kwargs.get('use_unicode', True))

self.cursor = self.conn.cursor()

print("\nMySQL连接成功!\n")

if kwargs.get('db'):

self.SetDatabase(kwargs.get('db'))

except Exception as errMsg:

raise Exception(errMsg)

# ---------------------------------------------------------------------------------------------------

def SetDatabase(self, db):

try:

self.cursor.execute('USE {0}'.format(db)) # 设置(修改)当前数据库

print("\n已连接数据库{0}\n".format(db))

except Exception as e:

print(e)

def CloseConnection(self):

# 关闭数据库连接

self.conn.close()

print("\nMySQL连接已关闭!\n")

class MysqlPython(Client):

def __init__(self, **kwargs):

Client.__init__(self, db=kwargs.get('db', 'testdb'), host=kwargs.get('host', 'localhost'),

password=kwargs.get('password', '123'))

self.COMMIT_THRESHOLD = 10000

def DescDatabases(self):

"""查看所有数据库容量大小"""

sql = """select

table_schema,

sum(table_rows) as '记录数',

sum(truncate(data_length/1024/1024, 2)) as '数据容量(MB)',

sum(truncate(index_length/1024/1024, 2)) as '索引容量(MB)'

from information_schema.tables

group by table_schema

order by sum(data_length) desc, sum(index_length) desc

"""

self.cursor.execute(sql)

info = self.cursor.fetchall()

return info

def DescDatabase(self, db):

"""查看(指定库)mysql库容量大小"""

sql = """select

table_schema as '数据库',

sum(table_rows) as '记录数',

sum(truncate(data_length/1024/1024, 2)) as '数据容量(MB)',

sum(truncate(index_length/1024/1024, 2)) as '索引容量(MB)'

from information_schema.tables

where table_schema='{0}';

""".format(db)

self.cursor.execute(sql)

info = self.cursor.fetchall()

return info

def DescDbsTables(self):

"""查看所有数据库各表容量大小"""

sql = """select

table_schema as '数据库',

table_name as '表名',

table_rows as '记录数',

truncate(data_length/1024/1024, 2) as '数据容量(MB)',

truncate(index_length/1024/1024, 2) as '索引容量(MB)'

from information_schema.tables

order by data_length desc, index_length desc

"""

self.cursor.execute(sql)

info = self.cursor.fetchall()

return info

def DescDbTables(self, db):

"""查看(指定库)各表容量大小"""

sql = """select

table_schema as '数据库',

table_name as '表名',

table_rows as '记录数',

truncate(data_length/1024/1024, 2) as '数据容量(MB)',

truncate(index_length/1024/1024, 2) as '索引容量(MB)'

from information_schema.tables

where table_schema='{0}'

order by data_length desc, index_length desc;

""".format(db)

self.cursor.execute(sql)

info = self.cursor.fetchall()

return info

if __name__ == '__main__':

client = MysqlPython()

print(client.DescDatabases())

print(client.DescDatabase(db='mysql'))

print(client.DescDbsTables())

print(client.DescDbTables(db='mysql'))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值