如何根据条件输出MySQL表Insert行?

Bash

1 前言

一个问题,一篇文章,一出故事。
笔者执行NextCloud的维护任务,需要从数据表中删除用户数据,于是笔者想着删除前先备份用于数据,于是想到把查询的条件备份数据并输出为Insert的插入语句,本章将使用函数实现转换功能,当需要恢复数据时直接筛选出来直接插入。

2 最佳实践

#!/bin/bash

mysqlHost="localhost"
mysqlPort="3306"
mysqlDataBase="nextcloud"
mysqlUser="mysqlUser"
mysqlPasswd="mysqlPassword"

selectToInsert() {
        local tableName="$1"
        local queryCondition="$2"
        mysqldump -u"$mysqlUser" -p"$mysqlPasswd" -h "$mysqlHost" \
                --complete-insert --no-create-info --extended-insert=FALSE \
                "$mysqlDataBase" "$tableName" --where="$queryCondition" \
                | grep "INSERT INTO" | sed "s/INSERT INTO/INSERT INTO \`$mysqlDataBase\`./"
}

# 使用示例
userID="00951F72-ACEC-4A4E-8330-8AEA96562409"
queryCondition="uid_owner = '$userID' or uid_initiator = '$userID' or share_with = '$userID'"
selectToInstall "oc_share" "$queryCondition"
没有评论

发表回复

Bash
如何自动启动失败的服务?

1 前言 一个问题,一篇文章,一出故事。 今天遇到一个内部服务异常退出,我们希望有个守护进程每隔5分 …

MySQL & MariaDB
如何启用MariaDB密码验证插件?

1 前言 一个问题,一篇文章,一出故事。 MariaDB 提供了三种密码验证插件, – …

MySQL & MariaDB
如何部署Oracle Linux 9.x MySQL 8.x?

1 前言 MySQL相信不用笔者多做介绍,本章将要使用yum部署MySQL 8。 2 最佳实践 2. …