如何把mysql查询结果存储在数组里?
mysql 5.7以上已经支持json格式了
如果是老版本的,建议把数组内转换成字符串数字,避免like查询到别的值上面,比如
[1,11,111,2,55,5]
你查询like '%5%'的时候,55也会出来
springboot如何把数组存入mysql?
Spring Boot可以通过使用JdbcTemplate或者MyBatis进行对MySQL数据库进行操作,如果要将数组存入到MySQL中,可以通过如下步骤进行实现:
1. 建立一个连接MySQL的数据源和对应的JdbcTemplate对象(或者使用MyBatis配置连接)。
2. 创建一个MySQL表,使其有足够的字段来存储数组元素。若以字符串形式存储,则可定义一个包含数组元素的字符串类型的字段;若以独立的行存储,则可定义多个字段,每个字段存储一个数组元素。
3. 将数组转换为字符串(以逗号分隔的方式),或者单独插入MySQL表中的各个字段中,组成MySQL表字段对应的数据并执行SQL语句。
如果要将数组的每个元素分别插入到不同的行中,则可以使用for循环遍历数组,分别为每个元素执行SQL插入操作进行实现。
需要注意的是,在向数据库插入数组或其他类型的数据时,要注意防止SQL注入等安全问题。为此,一般建议在提交数据前先使用参数化查询等方式对数据进行验证和转换。
在Spring Boot中,可以通过JPA将数组存入MySQL数据库。主要步骤如下:
1. 定义实体类,包含数组属性和映射注解:
java
@Entity
图片来源:网络
public class User {
@Id
private Long id;
private String[] hobbies; // 数组属性
}
2. 创建Repository接口来操作实体:
java
public interface UserRepository extends JpaRepository<User, Long> {
}
3. 向数据库插入数据:
java
User user = new User();
user.setId(1L);
user.setHobbies(new String[]{"music", "movie"});
UserRepository userRepository = ctx.getBean(UserRepository.class);
userRepository.save(user);
4. 从数据库查询数据:
java
User user = userRepository.findById(1L).get();
String[] hobbies = user.getHobbies(); // 获取数组属性
5. 在数据库中,数组属性会被存储为多个字段:
mysql> select * from user;
+----+----------+----------+
| id | hobbies1 | hobbies2 |
+----+----------+----------+
| 1 | music | movie |
+----+----------+----------+