欢迎光临
我们一直在努力

脚本找出mysql中缺少主键的表

有时候早期建的表上可能缺少主键,这样容易导致查询或者主从复制比较慢。

下面是一个小的脚本,用于找出没有主键的表。

#!/bin/bash

# 找出没有主键的表

# Date: 2017/06/05

source /etc/profile

LOG=”/tmp/nopk.log_$(date +%F)”

user=’root’

host=’localhost’

pass=’123456′

sock=’/tmp/mysql.sock’

MYSQL_CMD=”mysql -u$user -h$host -p$pass -S$sock”

dbs=$($MYSQL_CMD 2>/dev/null -BNe “select SCHEMA_NAME from information_schema.SCHEMATA where SCHEMA_NAME not in (‘information_schema’,’performance_schema’)”)

for db in $dbs; do 

$MYSQL_CMD information_schema 2>/dev/null -NBe “select distinct TABLE_SCHEMA,table_name from columns where  TABLE_SCHEMA = ‘$db’ and table_name not in ( select distinct table_name from COLUMNS  where TABLE_SCHEMA = ‘$db’ and (column_key  = ‘PRI’ or column_key = ‘UNI’) )” | tee -a $LOG

done

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。