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

那些网站是vue做的凡科网站制作

那些网站是vue做的,凡科网站制作,网站建设+管理系统开发,ae在线生成视频总览 我们将讨论的主题包括使用Spring Batch进行批处理的基本概念#xff0c;以及如何将数据从CSV导入数据库。 0 – Spring Batch CSV处理示例应用程序 我们正在构建一个应用程序#xff0c;该应用程序演示Spring Batch处理CSV文件的基础。 我们的演示应用程序将允许我们处… 总览 我们将讨论的主题包括使用Spring Batch进行批处理的基本概念以及如何将数据从CSV导入数据库。 0 – Spring Batch CSV处理示例应用程序 我们正在构建一个应用程序该应用程序演示Spring Batch处理CSV文件的基础。 我们的演示应用程序将允许我们处理CSV文件其中包含数百条日本动漫标题的记录。 0.1 – CSV 我已经从这个Github存储库中下载了将要使用的CSV文件它提供了相当全面的动漫列表。 这是在Microsoft Excel中打开的CSV的屏幕截图 查看并从 Github 下载代码 1 –项目结构 2 –项目依赖性 除了典型的Spring Boot依赖关系外我们还包括spring-boot-starter-batch这是对Spring Batch的依赖顾名思义和hsqldb用于内存数据库。 我们还包括ToStringBuilder的commons-lang3。 ?xml version1.0 encodingUTF-8? project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersiongroupIdcom.michaelcgood/groupIdartifactIdmichaelcgood-spring-batch-csv/artifactIdversion0.0.1/versionpackagingjar/packagingnamemichaelcgood-spring-batch-csv/namedescriptionMichael C Good - Spring Batch CSV Example Application/descriptionparentgroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-parent/artifactIdversion1.5.7.RELEASE/versionrelativePath / !-- lookup parent from repository --/parentpropertiesproject.build.sourceEncodingUTF-8/project.build.sourceEncodingproject.reporting.outputEncodingUTF-8/project.reporting.outputEncodingjava.version1.8/java.version/propertiesdependenciesdependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-batch/artifactId/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-jpa/artifactId/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactId/dependencydependencygroupIdorg.hsqldb/groupIdartifactIdhsqldb/artifactId/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-test/artifactIdscopetest/scope/dependency!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 --dependencygroupIdorg.apache.commons/groupIdartifactIdcommons-lang3/artifactIdversion3.6/version/dependency/dependenciesbuildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project3 –模型 这是对动漫领域进行建模的POJO。 字段是 ID。 为了简单起见我们将ID视为字符串。 但是可以将其更改为其他数据类型例如Integer或Long。 标题。 这是动画的标题适合作为String。 描述。 这是动漫的描述比标题长也可以视为字符串。 需要注意的是我们的三个字段的类构造函数public AnimeDTO字符串id字符串标题字符串描述。 这将在我们的应用程序中使用。 同样像往常一样我们需要创建一个没有参数的默认构造函数否则Java会抛出错误。 package com.michaelcgood;import org.apache.commons.lang3.builder.ToStringBuilder; /*** Contains the information of a single anime** author Michael C Good michaelcgood.com*/public class AnimeDTO {public String getId() {return id;}public void setId(String id) {this.id id;}public String getTitle() {return title;}public void setTitle(String title) {this.title title;}public String getDescription() {return description;}public void setDescription(String description) {this.description description;}private String id;private String title;private String description;public AnimeDTO(){}public AnimeDTO(String id, String title, String description){this.id id;this.title title;this.description title;}Overridepublic String toString() {return new ToStringBuilder(this).append(id, this.id).append(title, this.title).append(description, this.description).toString();}}4 – CSV文件到数据库配置 该类中发生了很多事情并且不是一次编写的因此我们将逐步学习代码。 访问Github以查看完整的代码。 4.1 –读者 如Spring Batch文档所述FlatFileIteamReader将“从平面文件中读取数据行这些文件通常描述记录的数据字段由文件中的固定位置定义或由某些特殊字符例如逗号分隔”。 我们正在处理CSV因此当然用逗号分隔数据这使其非常适合与我们的文件一起使用。 Beanpublic FlatFileItemReaderAnimeDTO csvAnimeReader(){FlatFileItemReaderAnimeDTO reader new FlatFileItemReaderAnimeDTO();reader.setResource(new ClassPathResource(animescsv.csv));reader.setLineMapper(new DefaultLineMapperAnimeDTO() {{setLineTokenizer(new DelimitedLineTokenizer() {{setNames(new String[] { id, title, description });}});setFieldSetMapper(new BeanWrapperFieldSetMapperAnimeDTO() {{setTargetType(AnimeDTO.class);}});}});return reader;} 重要事项 FlatFileItemReader使用模型进行参数化。 4.2 –处理器 如果要在将数据写入数据库之前对其进行转换则需要一个ItemProcessor。 我们的代码实际上并没有应用任何业务逻辑来转换数据但是我们允许这种能力。 4.2.1 – CsvFileToDatabaseConfig.Java中的处理器 csvAnimeProcessor返回AnimeProcessor对象的新实例我们将在下面进行检查。 BeanItemProcessorAnimeDTO, AnimeDTO csvAnimeProcessor() {return new AnimeProcessor();} 4.2.2 – AnimeProcessor.Java 如果我们想在写入数据库之前应用业务逻辑则可以在写入数据库之前操纵字符串。 例如您可以在getTitle之后添加toUpperCase以使标题大写然后再写入数据库。 但是我决定不对此示例处理器执行此操作或不应用任何其他业务逻辑因此未进行任何操作。 该处理器仅在此处进行演示。 package com.michaelcgood;import org.slf4j.Logger; import org.slf4j.LoggerFactory;import org.springframework.batch.item.ItemProcessor;public class AnimeProcessor implements ItemProcessorAnimeDTO, AnimeDTO {private static final Logger log LoggerFactory.getLogger(AnimeProcessor.class);Overridepublic AnimeDTO process(final AnimeDTO AnimeDTO) throws Exception {final String id AnimeDTO.getId();final String title AnimeDTO.getTitle();final String description AnimeDTO.getDescription();final AnimeDTO transformedAnimeDTO new AnimeDTO(id, title, description);log.info(Converting ( AnimeDTO ) into ( transformedAnimeDTO ));return transformedAnimeDTO;}}4.3 –作家 csvAnimeWriter方法负责将值实际写入我们的数据库。 我们的数据库是内存中的HSQLDB但是此应用程序使我们可以轻松地将一个数据库换成另一个数据库。 dataSource是自动连线的。 Beanpublic JdbcBatchItemWriterAnimeDTO csvAnimeWriter() {JdbcBatchItemWriterAnimeDTO excelAnimeWriter new JdbcBatchItemWriterAnimeDTO();excelAnimeWriter.setItemSqlParameterSourceProvider(new BeanPropertyItemSqlParameterSourceProviderAnimeDTO());excelAnimeWriter.setSql(INSERT INTO animes (id, title, description) VALUES (:id, :title, :description));excelAnimeWriter.setDataSource(dataSource);return excelAnimeWriter;}4.4 –步骤 步骤是一个域对象它包含批处理作业的独立顺序阶段并包含定义和控制实际批处理所需的所有信息。 现在我们已经为数据创建了读取器和处理器我们需要编写数据。 对于读取我们一直在使用面向块的处理这意味着我们一次读取了一个数据。 面向块的处理还包括在事务边界内创建将被写出的“块”。 对于面向块的处理您可以设置提交间隔一旦读取的项目数等于已设置的提交间隔就可以通过ItemWriter写入整个块并提交事务。 我们将块间隔大小设置为1。 我建议阅读有关面向块处理的Spring Batch文档 。 然后读取器处理器和写入器调用我们编写的方法。 Beanpublic Step csvFileToDatabaseStep() {return stepBuilderFactory.get(csvFileToDatabaseStep).AnimeDTO, AnimeDTOchunk(1).reader(csvAnimeReader()).processor(csvAnimeProcessor()).writer(csvAnimeWriter()).build();}4.5 –工作 作业由步骤组成。 我们将参数传递到下面的Job中因为我们想跟踪Job的完成情况。 BeanJob csvFileToDatabaseJob(JobCompletionNotificationListener listener) {return jobBuilderFactory.get(csvFileToDatabaseJob).incrementer(new RunIdIncrementer()).listener(listener).flow(csvFileToDatabaseStep()).end().build();} 5 –作业完成通知监听器 下面的类自动连接JdbcTemplate因为我们已经设置了dataSource并且我们想轻松地进行查询。 我们查询的结果是AnimeDTO对象的列表。 对于返回的每个对象我们将在控制台中创建一条消息以显示该项目已被写入数据库。 package com.michaelcgood;import java.sql.ResultSet; import java.sql.SQLException; import java.util.List;import org.slf4j.Logger; import org.slf4j.LoggerFactory;import org.springframework.batch.core.BatchStatus; import org.springframework.batch.core.JobExecution; import org.springframework.batch.core.listener.JobExecutionListenerSupport; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.RowMapper; import org.springframework.stereotype.Component;Component public class JobCompletionNotificationListener extends JobExecutionListenerSupport {private static final Logger log LoggerFactory.getLogger(JobCompletionNotificationListener.class);private final JdbcTemplate jdbcTemplate;Autowiredpublic JobCompletionNotificationListener(JdbcTemplate jdbcTemplate) {this.jdbcTemplate jdbcTemplate;}Overridepublic void afterJob(JobExecution jobExecution) {if(jobExecution.getStatus() BatchStatus.COMPLETED) {log.info( JOB FINISHED Verifying the results....\n);ListAnimeDTO results jdbcTemplate.query(SELECT id, title, description FROM animes, new RowMapperAnimeDTO() {Overridepublic AnimeDTO mapRow(ResultSet rs, int row) throws SQLException {return new AnimeDTO(rs.getString(1), rs.getString(2), rs.getString(3));}});for (AnimeDTO AnimeDTO : results) {log.info(Discovered AnimeDTO in the database.);}}}}6 – SQL 我们需要为我们的数据库创建一个模式。 如前所述我们已将所有字段都设置为字符串以便于使用因此我们将其数据类型设置为VARCHAR。 DROP TABLE animes IF EXISTS; CREATE TABLE animes (id VARCHAR(10),title VARCHAR(400),description VARCHAR(999) );6 –主 这是带有main的标准类。 如Spring文档所述 SpringBootApplication是一个方便注释其中包括 Configuration EnableAutoConfiguration EnableWebMvc和ComponentScan 。 package com.michaelcgood;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication;SpringBootApplication public class SpringBatchCsvApplication {public static void main(String[] args) {SpringApplication.run(SpringBatchCsvApplication.class, args);} }7 –演示 7.1 –转换 FieldSet通过处理器输入“ Converting”被打印到控制台。 7.2 –在数据库中发现新项目 当Spring Batch Job完成时我们选择所有记录并将它们分别打印到控制台。 7.3 –批处理完成 批处理完成后这就是打印到控制台的内容。 Job: [FlowJob: [namecsvFileToDatabaseJob]] completed with the following parameters: [{run.id1, -spring.output.ansi.enabledalways}] and the following status: [COMPLETED] Started SpringBatchCsvApplication in 36.0 seconds (JVM running for 46.616)8 –结论 Spring Batch建立在基于POJO的开发方法和Spring Framework的用户友好性的基础上使开发人员可以轻松地创建企业级批处理。 源代码在 Github上 翻译自: https://www.javacodegeeks.com/2017/10/spring-batch-csv-processing.html
http://www.ihoyoo.com/news/126519.html

相关文章:

  • 赵公口网站建设公司网络营销技巧培训
  • 常州网站设计一个公司网站后台怎么做
  • 阿里云服务器做电影网站吗云南微网站建设的公司有哪些
  • 好看的知名企业网站河北常见网站建设价格
  • eclips怎么做网站公司设计一个网站需要多久
  • 网站建设虚拟空间深圳软件定制开发公司排行
  • 硅藻泥网站怎么做网站建设前期规划方案范文
  • 钢球网架公司优化网站内链
  • 电子商务网站平台建设怎样建设网站呢
  • 上海网站开发有限公司网站建设费用什么意思
  • 做酒招代理的网站普通网站要什么费用
  • 网站怎么做移动的窗口h5做网站什么软件
  • 上海公司注册网上查询为什么做网站结构优化
  • 做分享衣服网站的初衷是什么配置asp网站
  • 怎么做网站上打字体能看人与动物做的网站
  • 做网站写代码好还是模板凡科是大厂吗
  • 做教育app的网站开发小程序需要什么技术
  • 关于做网站策划书wordpress登录界面出错
  • 本地主机 搭建网站网站头部固定
  • 做暖网站怎么建设域名和网站
  • 个人网站备案名wordpress 一键转发
  • 企业网站的技术维护内容主要包括网站开发主管待遇
  • 昆明企业网站建设网站建设课程设计论文
  • 网站分别怎么做网站赚流量
  • 东莞网站主页制作惠州手机网站建设
  • 妇女之家网站建设方案主题字体wordpress
  • 中国贸易网站上海seo优化公司kinglink
  • 网络网站建设办公网站服务器租用 配置
  • 一个网站的渠道网络建设版面设计绘画
  • 企业不建立网站吗网站优化公司排行