我想在mysql中保存阿拉伯字符,在我的CSV文件中同时包含阿拉伯字符和英语字符。
当我显示控制台日志时,我可以看到带有阿拉伯字符的字符串,但是在MySQL中,我看到了“ ????”字符
如果我的CSV文件,数据库和表均采用UTF-8编码
我也将其添加到application.properties中:
spring.datasource.url=jdbc:mysql://localhost:3306/contacts?useUnicode=true&characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=
我正在使用Spring Batch版本4,并使用简单的CSV到MySQL
我必须添加什么?
其他代码:
@Bean
public FlatFileItemReader<Csv> fileReader(@Value("${input}") Resource in) throws Exception {
return new FlatFileItemReaderBuilder<Csv>()
.name("file-reader")
.resource(in)
.targetType(Csv.class)
.linesToSkip(1)
.delimited().delimiter(";").names(new String[]{"Name","Email","UID","Username","Phone","Location","Birthday","Gender"})
.build();
}
@Bean
public JdbcBatchItemWriter<Contact> jdbcWriter(DataSource ds) {
return new JdbcBatchItemWriterBuilder<Contact>()
.dataSource(ds)
.sql("INSERT INTO contact (UID, name, username, gender, phone, email, birthday, location, country_id, city_id, state_id) VALUES (:uid, :name, :username, :gender, :phone, :email, :birthday, :location, :countryId, :cityId, :stateId)")
.beanMapped()
.build();
}