Mysql
 sql >> Base de données >  >> RDS >> Mysql

Diviser les valeurs séparées par des virgules en lignes individuelles

C'est quelque chose qui est généralement mieux fait dans autre chose que SQL, comme Java.

Le pseudo-code pourrait être :

List<String> names = jdbcTemplate.query("select A from your_table", new RowMapper() {
    public Object mapRow(ResultSet resultSet, int i) throws SQLException {
        return resultSet.getString(1);
    }
});

for (String name : names) {
    String[] strings = name.split("[\\w,]");
    for (int i = 0; i < strings.length; i++) {
        String string = strings[i];
        jdbcTemplate.update("insert ignore into new_table (B) values (?)", string);
    }

}