如何对 MYSQL 大数据库执行表数据删除 *** 作,单表数据量超过 15.6G

如何对 MYSQL 大数据库执行表数据删除 *** 作,单表数据量超过 15.6G,第1张

如何对 MYSQL 大数据执行表数据删除 *** 作,单表数据量超过 15.6G

delete 语句不影响表所占用的 extent,高水线(high watermark)保持原位置不动

drop 语句将表所占用的空间全部释放。

truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage;truncate 会将高水线复位(回到最开始)。

MYSQL里面没有限制文件大小的语句,但是事实上你的文件是有大小限制的--受 *** 作系统的限制,比如32位 *** 作系统单个文件有2G大小的限制。

你无法插入数据,要看具体的情况,除了上面说的文件大小超过2G,主要有一下两种可能:

一是插入的数据在唯一索引或者主键字段上有重复。看看表有那些索引,如果插入数据和以前的有重复当然就会失败,删除以前的数据当然就能插入了。这种情况下,插入数据的时候会报告相应的错误,错误详细信息有说明是哪个字段上的所有有重复。

二是数据表损坏,特别是假如你说你的表根本没有索引的时候,那么损坏的可能性就相当的大。这种情况下数据表可能是只读状态,也甚至可能是根本无法打开,插入失败的时候可能会报告数据表被别的进程占用。处理的方法是用MYSQL的系统工具进行修复,比如MYISAMCHK。

,先计算mysql数据库目录下的每个数据库大小,然后与容量限制进行比较,如果超过容量,则revoke该数据库的insert权限,让用户数据库不能再增长。

脚本如下:

###begin srcript --author pat.dong####

# 如果用户空间超过,此文件将会作为邮件的内容发送到用户信箱

sizeover="/etc/sizeover.log"

dblist="/tmp/dblist"

mysql_path=/usr/local/mysql/bin

# 将数据库名称输出

$mysql_path/mysql -uroot -e "show databases">$dblist

# 删除第一栏 "Database"

sed 1d $dblist >/tmp/tmp123456

cat /tmp/tmp123456 >$dblist

# 数据库的数据路径

DB_PATH="/www/mysql"

# 用户所能使用的最大空间 单位 kb

LIMIT_SIZE=2048

#mysql_quota文件记录每个数据库的配额,内容如下:

####mysql_quota file begin######

cn-ce 10000

cnmr 2048

fulin 2048

ishunde 2048

jljust 15000

####end mysql_quota#####

# mysql 这个数据库不必改

cat $dblist | while read bdo

if [ $b != "mysql" ] &&[ -d $DB_PATH/$b ]

then

SIZE=`du $DB_PATH/$b -sk|awk {'print $1'}`

LIMIT_SIZE=`cat quota |grep $b|awk {'print $2'}`

echo "User Size is "$SIZE",Limt Size is "$LIMIT_SIZE

if [ $SIZE -gt $LIMIT_SIZE ]

then

# mysql -uroot -prootpwd -n -e "revoke insert on $b.* from $b@hostname"

# sendmail [email protected] <$sizeover

echo $b" is over quota"

else

# mysql -uroot -prootpwd -n -e "grant insert on $b.* to $b@hostname"

echo $b" is no over quota"

fi

# mysql -uroot -prootpwd -n -e "flush privileges"

fi

done

####end script#####


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10823211.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-11
下一篇 2023-05-11

发表评论

登录后才能评论

评论列表(0条)

保存