当前位置: 首页 > news >正文

推荐个2021能看的网站免费东莞市朝阳企讯通

推荐个2021能看的网站免费,东莞市朝阳企讯通,做网站开发需要学什么软件,那个网站学做披萨比较好文章目录 前言存储数据库存储数据表 前言 数据库备份是开发工作中经常要做的事情,好处是mysql提供了一个非常好的命令 mysqldump,直接调用它就可以将数据以sql文件的形式备份出来。但是直接写命令非常不方便,遇到定时备份或者指定备份那么就需…

在这里插入图片描述

文章目录

  • 前言
  • 存储数据库
  • 存储数据表

前言

  数据库备份是开发工作中经常要做的事情,好处是mysql提供了一个非常好的命令 mysqldump,直接调用它就可以将数据以sql文件的形式备份出来。但是直接写命令非常不方便,遇到定时备份或者指定备份那么就需要代码调用。下面是一个使用java代码调用该命令的小示例:

mysqldump -u username -p password -h host -P port exportDatabaseName exportPath

  在进行导出的时候,需要注意命令语句的运行环境,如果已经将mysql安装路径下的bin加入到系统的path变量中,那么在导出的时候可以直接使用命令语句,否则,就需要在执行命令语句的时候加上命令所在位置的路径,即mysql安装路径想的bin下的mysqldump命令。

存储数据库

public class DataSyncTransfer {/** MySQL安装目录的Bin目录的绝对路径 */private static String mysqlBinPath = "/usr/local/mysql/bin/";private static String mysqldump = mysqlBinPath + "mysqldump";/*** 备份 MySQL 数据库* * @param clientIp   访问MySQL数据库的主机* @param port       访问MySQL数据库的端口* @param userName   访问MySQL数据库的用户名* @param password   访问MySQL数据库的密码* @param database   需要备份的数据库,多个数据库之间使用逗号分隔* @param backupFile 备份文件存放的路径,如果指定路径的文件不存在会自动生成*/public static boolean backupDatabase(String clientIp, int port, String userName, String password, String database,String backupPath) throws Exception {// 当前日期String currentDate = new SimpleDateFormat("yyyy-MM-dd").format(new Date());// 当前时间String currentTime = new SimpleDateFormat("HH-mm-ss").format(Calendar.getInstance().getTime());// 备份文件名String backupFileName = database + "-" + currentDate + "-" + currentTime + ".sql";// 备份文件路径String backupFilePath = backupPath + backupFileName;// 创建备份文件存放目录,如果已经存在则不创建new File(backupPath).mkdirs();// 新建命令列表List<String> commandList = new ArrayList<>();// 添加命令:备份 MySQL 数据库commandList.add(mysqldump);// 添加命令参数:MySQL 服务器地址if (StringUtils.isNoneBlank(clientIp)) {commandList.add("--host=" + clientIp);}// 添加命令参数:MySQL 用户名commandList.add("--user=" + userName);// 添加命令参数:备份文件路径commandList.add("--result-file=" + backupFilePath);// 添加命令参数:指定要备份的数据库commandList.add("--databases");// 添加要备份的数据库名称commandList.add(database);// 创建进程构建器ProcessBuilder pb = new ProcessBuilder(commandList);// 设置 MySQL 密码pb.environment().put("MYSQL_PWD", password);// 启动进程Process process = pb.start();readStringFromInputStream(process.getInputStream(), backupFilePath);// 等待进程结束int processComplete = process.waitFor();if (processComplete == 0) { // 如果进程成功结束return true;} else { // 如果进程没有成功结束return false;}}/*** 存储文件*/private static void readStringFromInputStream(InputStream stream, String backupFilePath) throws IOException {byte[] buff = new byte[128];int n;FileOutputStream fileOutputStream = null;StringBuilder sb = new StringBuilder();try {while ((n = stream.read(buff)) != -1) {sb.append(new String(buff, 0, n));}fileOutputStream = new FileOutputStream(new File(backupFilePath));fileOutputStream.write(sb.toString().getBytes());} finally {fileOutputStream.close();stream.close();}}
}

存储数据表

public class DataSyncTransfer {/** MySQL安装目录的Bin目录的绝对路径 */private static String mysqlBinPath = "/usr/local/mysql/bin/";private static String mysqldump = mysqlBinPath + "mysqldump";/*** 备份数据表* * @param clientIp   访问MySQL数据库的主机* @param port       访问MySQL数据库的端口* @param userName   访问MySQL数据库的用户名* @param password   访问MySQL数据库的密码* @param database   需要备份的数据库* @param tableName  需要备份的数据库,多个表之间使用空格分隔* @param backupFile 备份生成的文件路径,如果指定路径的文件不存在会自动生成*/public static boolean backupTable(String clientIp, int port, String userName, String password, String database,String tableNames, String backupPath) throws Exception {// 根据逗号分隔符,将要备份的数据库名称拆分成数组// String[] tableArr = tableNames.split(",");// 当前日期String currentDate = new SimpleDateFormat("yyyyMMdd").format(new Date());// 当前时间String currentTime = new SimpleDateFormat("HHmmss").format(Calendar.getInstance().getTime());// 备份文件名String backupFileName = database + "-" + currentDate + currentTime + ".sql";// 备份文件路径String backupFilePath = Paths.get(backupPath, backupFileName).toFile().getPath();String command = mysqldump + " -u" + userName + " -p" + password + " " + database + " " + tableNames;Process process = Runtime.getRuntime().exec(command);readStringFromInputStream(process.getInputStream(), backupFilePath);// 等待进程结束int processComplete = process.waitFor();if (processComplete == 0) { // 如果进程成功结束return true;} else { // 如果进程没有成功结束return false;}}/*** 存储文件*/private static void readStringFromInputStream(InputStream stream, String backupFilePath) throws IOException {byte[] buff = new byte[128];int n;FileOutputStream fileOutputStream = null;StringBuilder sb = new StringBuilder();try {while ((n = stream.read(buff)) != -1) {sb.append(new String(buff, 0, n));}fileOutputStream = new FileOutputStream(new File(backupFilePath));fileOutputStream.write(sb.toString().getBytes());} finally {fileOutputStream.close();stream.close();}}
}
http://www.yayakq.cn/news/858306/

相关文章:

  • 优化设计全部答案网站页面布局优化
  • 深圳外贸建站及推广中国广告公司
  • 好的网站首页建设公司wordpress koncept 下载
  • 淘客网站开发流程p2p网站开发思路方案
  • 网站项目申请app开发公司名称
  • 佛山电子商务网站设计wordpress使用非80端口
  • 做国际网站装修许昌seo推广
  • 中文网站建设制作阳泉哪里做网站
  • 网站建设中html代码做外贸网站流程
  • 重庆做宁波seo外包代运营
  • 兰州网站建设与优化推广自己做网站要不要钱
  • 郑州网站建设推广渠道阿里云能做网站么
  • 群辉服务器建设的网站微帮本地推广平台
  • 百度搜索优化建议象山seo外包服务优化
  • 公司名称域名网站网络行业做什么挣钱
  • 苏州手机网站开发公司北京做企业网站的公司
  • 优质的营销网站建设西安十强互联网站建设公司
  • 自己家里做网站网速慢wordpress预览pdf
  • 河池网站开发工程师招聘网焦作seo公司
  • 电白区建设局网站怎么做淘客的网站
  • linux 做网站wordpress 修改端口
  • 爱站库在线crm软件有哪些优势?
  • 网站开发的前后端是哪些网页设计实训报告前言
  • 网站建设公司选择意见书wordpress中的全站链接怎么改
  • 杭州专业做网站的南昌快速排名优化
  • 直播网站开发报价百度资源搜索
  • 吉安市网站制作美食网站建设的内容分析
  • 国内 响应式网站境外企业网站推广
  • 自助建站营销招商wordpress 动态背景图片
  • 鲜花网站建设规模设想经典重庆论坛新闻评论