如何根据条件输出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"
没有评论

发表回复

MySQL & MariaDB
如何升级MariaDB数据库?

1 前言 一个问题,一篇文章,一出故事。 今天测试Keycloak的升级,遇到如下错误提示, RRO …

Bash
如何自动根据职位设置NextCloud用户配额?

1 前言 一个问题,一篇文章,一出故事。 今天更新一个自动根据AD中的职位(title)设置Next …

Bash
如何在远程主机执行函数?

1 前言 一个问题,一篇文章,一出故事。 笔者今天想在远程机器执行本地脚本定义的函数,于是整理当前章 …