删除数据库中相关表中含有某字段值为XXX的数据,把数据库相关表中某字段的值统一修改为XXX

50 篇文章 1 订阅
30 篇文章 0 订阅

自己封装的数据库工具操作类。在数据库含有脏数据的时候很好用,也要小心,因为是删除和修改操作!!!

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Arrays;
import java.util.List;

import org.apache.log4j.Logger;

import com.jfinal.plugin.activerecord.Db;

/**
 * @author 黄宝康
 */
public class DbHelper {
    static Logger logger = Logger.getLogger(DbHelper.class);

    /**
     * @param conn
     *            数据库连接
     * @param field
     *            字段名称
     * @param value
     *            字段的值
     * @param domain
     *            数据库
     * @param exculdeTables
     *            排除删除该表相应记录 功能:删除数据库中所有表中含有该字段,并且记录中该字段的值为XXX
     *            exculdeTables传递null则删除所有
     * @return
     */
    public static void deleteAllLikeFieldFromDb(Connection conn, String field, String value, String domain, String exculdeTables[]) {
        try {
            DatabaseMetaData metaData = conn.getMetaData();
            ResultSet rs = metaData.getTables(null, metaData.getUserName(), null, new String[] { "TABLE" });// 获取到所有表
            while (rs.next()) {
                String tableName = rs.getString("TABLE_NAME");
                if (exculdeTables != null) {
                    List<String> excludeLists = Arrays.asList(exculdeTables);
                    if (excludeLists.contains(tableName.toLowerCase())) {
                        continue;
                    }
                }
                ResultSet columns = metaData.getColumns(conn.getCatalog(), metaData.getUserName(), tableName, null);// 获取到所有列
                while (columns.next()) {
                    if (columns.getString("COLUMN_NAME").equals(field.toUpperCase())) {// 说明该表字段中含有该列
                        String sql = "delete from " + tableName + " where " + field.toUpperCase() + " = ?";
                        Db.use(domain + "_w").update(sql, value);
                        logger.info("删除" + tableName + "表中字段名" + field.toUpperCase() + "=" + value + "的所有记录成功!");
                        break;
                    }
                }
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    // 把之前数据库表中该字段的值为xxxx改成新的值
    public static void updateAllLikeFieldFromDb(Connection conn, String field, String oldValue, String newValue, String domain,
            String exculdeTables[]) {
        try {
            DatabaseMetaData metaData = conn.getMetaData();
            ResultSet rs = metaData.getTables(null, metaData.getUserName(), null, new String[] { "TABLE" });// 获取到所有表
            while (rs.next()) {
                String tableName = rs.getString("TABLE_NAME");
                if (exculdeTables != null) {
                    List<String> excludeLists = Arrays.asList(exculdeTables);
                    if (excludeLists.contains(tableName.toLowerCase())) {
                        continue;
                    }
                }
                ResultSet columns = metaData.getColumns(conn.getCatalog(), metaData.getUserName(), tableName, null);// 获取到所有列
                while (columns.next()) {
                    if (columns.getString("COLUMN_NAME").equals(field.toUpperCase())) {// 说明该表字段中含有该列
                        String sql = "update " + tableName + " set " + field.toUpperCase() + " = ? where " + field.toUpperCase() + " = ?";
                        Db.use(domain + "_w").update(sql, newValue, oldValue);
                        logger.info("修改"+tableName+"表字段"+field.toUpperCase()+"所有为"+oldValue+"的值设为"+newValue+"成功!");
                        break;
                    }
                }
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}
/*
 * 第一个是数据库名称,对于MySQL,则对应相应的数据库,对于Oracle来说,则是对应相应的数据库实例,可以不填,
 * 也可以直接使用Connection的实例对象中的getCatalog()方法返回的值填充;
 * 第二个是模式,可以理解为数据库的登录名,而对于Oracle也可以理解成对该数据库操作的所有者的登录名
 * 。对于Oracle要特别注意,其登陆名必须是大写,不然的话是无法获取到相应的数据,而MySQL则不做强制要求。
 * 第三个是表名称,一般情况下如果要获取所有的表的话,可以直接设置为null,如果设置为特定的表名称,则返回该表的具体信息。
 * 第四个是类型标准,以数组形式传值,
 * 有"TABLE"、"VIEW"、"SYSTEM TABLE"、"GLOBAL TEMPORARY"、"LOCAL TEMPORARY"、"ALIAS" 和
 * "SYNONYM"这几个经典的类型,一般使用”TABLE”,即获取所有类型为TABLE的表
 * 它返回一个ResultSet对象,有10列,详细的显示了表的类型: TABLE_CAT String => 表类别(可为 null)
 * TABLE_SCHEM String => 表模式(可为 null) TABLE_NAME String => 表名称 TABLE_TYPE String
 * => 表类型。 REMARKS String => 表的解释性注释 TYPE_CAT String => 类型的类别(可为 null)
 * TYPE_SCHEM String => 类型模式(可为 null) TYPE_NAME String => 类型名称(可为 null)
 * SELF_REFERENCING_COL_NAME String => 有类型表的指定 "identifier" 列的名称(可为 null)
 * REF_GENERATION String
 */
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黄宝康

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值