如何从MYSQL数据库中删除所有视图?

时间:2012-09-13 17:32:20

标签: mysql sql-drop

我的数据库有很多视图,不可能一个一个地丢弃它们。

我想将它们全部删除,因为数据库不刷新视图中从中选择的表的结构更改。

2 个答案:

答案 0 :(得分:2)

如果要在MySQL客户端中执行此操作,可以使用information_schema动态生成DDL语句,将它们转储到SQL脚本,然后执行该脚本。

示例:

select concat('drop view ',table_schema,'.',table_name,';') as ddl 
into outfile '/tmp/drop_all_views.sql' 
from information_schema.views 
where table_schema = 'your_schema';

\. /tmp/drop_all_views.sql

答案 1 :(得分:0)

在网上搜索后,我找到了一个shell脚本来删除所有表格:http://www.cyberciti.biz/faq/how-do-i-empty-mysql-database/

然后,我更改了该脚本以删除数据库的所有视图。 这是最终结果:

#!/bin/bash
PREFIX=""
SUFFIX=""
HOST="localhost"
PORT="3306"

while getopts p:s:h:P: OPCAO; do
    case "${OPCAO}" in
      p) PREFIX="${OPTARG}" ;;
      s) SUFFIX="${OPTARG}" ;;
      h) HOST="${OPTARG}" ;;
      P) PORT="${OPTARG}" ;;
    esac
done

shift $((OPTIND-1))

MUSER="$1"
MPASS="$2"
MDB="$3"

# Detect paths
MYSQL=$(which mysql)
AWK=$(which awk)
GREP=$(which grep)

if [ $# -eq 0 ]
then
    echo "Usage: $0 [-h Host] [-P Port] [-p Prefix-View-Name] [-s Suffix-View-Name] {MySQL-User-Name} {MySQL-User-Password} {MySQL-Database-Name}"
    echo "Drops all views from a MySQL"
    exit 1
fi

TABLES=$($MYSQL -h $HOST -P $PORT -u $MUSER -p$MPASS $MDB -e "SELECT table_name FROM information_schema.views WHERE table_schema = '$MDB' AND table_name LIKE '$PREFIX%$SUFFIX';" | $AWK '{ print $1}')

for t in $TABLES
do
    echo "Deleting $t view from $MDB database..."
    $MYSQL -h $HOST -P $PORT -u $MUSER -p$MPASS $MDB -e "drop view $t"
done

此解决方案仅适用于使用类Unix系统的用户。

要调用脚本,我使用了:

./script.sh [-h host] [-P port] [-p prefixViewName] [-s suffixViewName] username password databaseName

编辑:我改进了脚本以接受选项参数,例如主机,端口以及前缀和后缀,以过滤将删除的视图。

相关问题