码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2017-06-05 22:10:15      阅读:280      评论:0      收藏:0      [点我收藏+]

标签:找出没有主键的表

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


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


#!/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



本文出自 “菜鸡” 博客,请务必保留此出处http://lee90.blog.51cto.com/10414478/1932495

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

标签:找出没有主键的表

原文地址:http://lee90.blog.51cto.com/10414478/1932495

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!