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

男女做暖暖的试看网站图片制作器在线制作

男女做暖暖的试看网站,图片制作器在线制作,网站安装出现dir,宁波营销型网站建设最近客户有个需求#xff0c;希望在后台增加手动备份功能#xff0c;将数据导出下载保存。 当然#xff0c;此方法不适用于海量数据的备份#xff0c;这只适用于少量数据的sql备份。 这是我生成的sql文件#xff0c;以及sql文件里的insert语句#xff0c;已亲测#x…最近客户有个需求希望在后台增加手动备份功能将数据导出下载保存。 当然此方法不适用于海量数据的备份这只适用于少量数据的sql备份。 这是我生成的sql文件以及sql文件里的insert语句已亲测可以直接执行 项目是SSM框架接下来就展示我的实现代码 首先是接受字段的实体类 Data public class ColumnsDto {/*** 表结构的主要字段**/private String column_name;//该字段则是表字段的数据类型 暂时不需要private String data_type;} 然后是用的到两个主要的sql 1.此sql用于查询表的有效字段信息table_schema当前的数据库名 select idqueryColumnsByTableName resultTypecom.hle.monitor.entity.vo.ColumnsDtoSELECTcolumn_name,data_typeFROMinformation_schema.COLUMNSWHEREtable_name #{tableName}AND table_schema supervision_dataORDER BY ordinal_position/select2.再用sql查询表的所有数据(注意此处表名需要要用$而不是#号) select idfindBackupAll resultTypejava.util.Mapselect * from ${tableName}/select 此处我省略了相应的service和mapper文件内容直接展示最重要的controller代码 import com.hle.monitor.entity.Results; import com.hle.monitor.entity.vo.ColumnsDto; import com.hle.monitor.service.UserService; import com.hle.monitor.util.DateUtils; import com.hle.monitor.util.MinIoUtil; import com.hle.monitor.util.ParameterUtil; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import org.apache.http.entity.ContentType; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Scope; import org.springframework.mock.web.MockMultipartFile; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile;import javax.annotation.Resource; import java.io.*; import java.lang.reflect.Field; import java.util.Arrays; import java.util.Date; import java.util.List; import java.util.Map;/*** author*/ CrossOrigin(origins *) RestController() RequestMapping(/backup) Api(tags 备份相关接口类) Scope(prototype) public class BackupController {Autowiredprivate UserService userService;ResourceMinIoUtil minIoUtil;//本地文件夹路径private static String backupFilePath ./sql/;ApiOperation(value 根据表名备份信息)GetMapping(/{tableName})public Results backupTable(PathVariable(tableName) String tableName) {//表有效字段信息ListColumnsDto columnsDtoList userService.queryColumnsByTableName(tableName);if(columnsDtoList.isEmpty()) return new Results(500, 该表无有效字段信息);//文件名--先在本地创建写入后再进行删除String fileName System.currentTimeMillis() - tableName .sql;try {//获取所有备份数据ListMapString, Object records userService.findBackupAll(tableName);String path backupFilePath fileName;//不存在文件夹则创建File directory new File(backupFilePath);directory.mkdirs();BufferedWriter writer new BufferedWriter(new FileWriter(path));for (Map record : records) {String insertStatement generateInsertStatement(tableName, record, columnsDtoList) ;;writer.write(insertStatement);writer.newLine();}writer.close();File file new File(path);InputStream inputStream new FileInputStream(file);MultipartFile multipartFile new MockMultipartFile(ContentType.APPLICATION_OCTET_STREAM.toString(), inputStream);minIoUtil.upload(multipartFile, ParameterUtil.bucketNameParam, fileName);//上传后 删除本地文件file.delete();System.out.println(Backup created successfully!);} catch (IOException e) {e.printStackTrace();return new Results(500, 操作失败);}return new Results(200, 操作成功, fileName);}//此方法需要以数据库取出来的字段信息为准--转换成sql的方法private String generateInsertStatement(String tableName, MapString, Object record, ListColumnsDto columnsDtoList) {StringBuilder builder new StringBuilder();builder.append(INSERT INTO ).append(tableName).append( ();//拼接列名columnsDtoList.forEach(columns - {builder.append(columns.getColumn_name()).append(, );});builder.setLength(builder.length() - 2);builder.append() VALUES ();//拼接值columnsDtoList.forEach(columns - {Object value record.get(columns.getColumn_name());if(value instanceof Date){Date date (Date) value;builder.append().append(DateUtils.parseDateToStr(date)).append(, );}else if(value instanceof String){builder.append().append(value).append(, );}else{builder.append(value).append(, );}});builder.setLength(builder.length() - 2);builder.append());return builder.toString();}//此方法用于直接取Object的字段信息做sql拼接--转换成sql的方法--已验证过private String generateInsertStatement(String tableName, Object record) {StringBuilder builder new StringBuilder();builder.append(INSERT INTO ).append(tableName).append( ();Arrays.stream(record.getClass().getDeclaredFields()).map(Field::getName).forEach(fieldName - builder.append(convertCamelCaseToSnakeCase(fieldName)).append(, ));builder.setLength(builder.length() - 2);builder.append() VALUES ();Arrays.stream(record.getClass().getDeclaredFields()).map(field - {field.setAccessible(true);try {return field.get(record);} catch (IllegalAccessException e) {e.printStackTrace();return null;}}).forEach(value - {if(value instanceof Date){//时间格式 转换为-YYYY_MM_DD_HH_MM_SSDate date (Date) value;builder.append().append(DateUtils.parseDateToStr(date)).append(, );}else if(value instanceof String){builder.append().append(value).append(, );}else{//int/double类型 不需要单引号builder.append(value).append(, );}});builder.setLength(builder.length() - 2);builder.append());return builder.toString();}//驼峰命令转换 userName-转换为-user_namepublic static String convertCamelCaseToSnakeCase(String input) {return input.replaceAll(([a-z])([A-Z]), $1_$2).toLowerCase();}}在controller中提供了两种方法可以参考一下然后直接调用接口就行 因为项目需要我是写入文件后再上传至minio文件服务器所以我要查看还需要去minio服务器查看下载或者调用现有的下载接口下载 这样就完成了根据sql文件数据备份
http://www.sczhlp.com/news/162116/

相关文章:

  • 动漫制作专业就业牡丹江网站seo
  • 网站的重要性网站制作工作室24小时接单
  • 建设银行快审额度查询网站娱乐类网站开发
  • 学asp.net 做网站 书籍网站开发完要怎么部署
  • 住房与城乡建设部建设环境工程技术中心网站尚义住房和城乡规划建设局网站
  • asp网站 底部版权所有卡片风格网站
  • 二级网站收录网页制作与网站建设完全学习手册下载
  • 长沙多用户商城网站建设好网站建设公司地址
  • 佛山网站建设优化wordpress 双首页
  • php做的汽车销售网站h5视频网站模板
  • 快速做网站用什么软件h5设计软件
  • 网站的营销特点织梦做淘宝客网站视频教程
  • 模版网站建设企业信息在线查询
  • 网站布局怎么设计从哪方面建设网站
  • 怎么做一个购物平台网站ui设计师简历
  • 做爰视频网站网站域名过户
  • 写作网站都有哪些seo外链怎么做能看到效果
  • 网站加速免费网络营销第三版课本
  • 深圳福田做网站公司哪家好网站未收录
  • ps个人网站建设滕州网站建设哪家好
  • 装修网站怎么做的好阿里云wordpress邮件
  • 网站网址没有被百度收录四川企业网站开发
  • 怎么在网上创建网站哪家做网站的好
  • 正能量网站推荐不需要下载看电视剧的免费网站app下载
  • 可信网站验证服务中心装修效果图哪里找
  • php网站怎么做集群用dw自己做网站
  • 天空彩票网站怎么做网站html5自适应屏幕
  • php做的网站怎么让外网访问wordpress charts
  • 网站名字起什么好处怀化网站优化公司有哪些
  • 怎么查网站是否备案wordpress文章描述调用修改