关于java清空表数据

一、起因
无意中发现了一个有趣的操作,于是就记录下来;

二、经过
请观察以下代码:

package com.liuzm;

import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;

public class RunTimeTest {

    public static void main(String[] args)  {
        String[] sb = new String[3];
        sb[0] = "cmd";
        sb[1] = "/c";
        sb[2] = new StringBuilder("mysql")
                .append(" -u").append("root")
                .append(" -p").append("root")
                .append(" -h").append("127.0.0.1")
                .append(" -P").append("3306")
                .append(" --default-character-set=UTF8")
                .toString();

        Process process = null;
        try {
             process = Runtime.getRuntime().exec(sb);
        } catch (IOException e) {
            e.printStackTrace();
        }
        OutputStream os = process.getOutputStream();
        String switchCmd = new StringBuilder("use ").append("my_test").toString();
        //获取truncate的命令语句
        String truncateCmd = new StringBuilder("TRUNCATE TABLE ").append("person").toString();

        OutputStreamWriter writer = new OutputStreamWriter(os);
        try {
            writer.write(switchCmd+ System.getProperty("line.separator") +truncateCmd);
            writer.flush();
            writer.close();
            os.close();
            int truncateRes = process.waitFor();

            if(truncateRes == 0){
                System.out.println("------表数据清理结束------");
            } else {
                System.out.println("表数据清理失败,truncateProcess.waitFor()返回值为:" + truncateRes);
            }
        } catch (InterruptedException | IOException e) {
            e.printStackTrace();
        }
    }
}

这是我模拟的一段代码,拿来直接可以用,记得改一下用户名和密码;如果在Linux环境下请把改为sb[1] = “-c”;先看一下这几个重载方法:
在这里插入图片描述
在看一下源码:
在这里插入图片描述
这几个方法实现都是exec(String command, String[] envp, File dir),可以回忆一下线程池;点进去看一下:
在这里插入图片描述
平时用的很少,就不往下看了;大概了解一下即可;

三、使用sql清空
表数据:
在这里插入图片描述
mapper接口

int TrancateTable();

mapper.xml

    <update id="TrancateTable">
      truncate table user_table;
    </update>

测试类

   @Test
    public void test4(){
        userMapper.TrancateTable();
    }

控制台输出

==>  Preparing: truncate table user_table; 
==> Parameters: 
<==    Updates: 0

数据库
在这里插入图片描述

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值