mysql一个字段存储多数据的查询方式

    在开发中我们经常遇到类似给文章添加标签的问题,一般常规的存储方式是在文章表(content)中建一个标签字段(tags),在这个字段中存入类似 1,3,5,22这种的数字字符串。这样就会产生一个问题就是在前端我们经常需要根据标签来展示文章。

方法一

    而通常这种的查询我们喜欢采用like(此处先不考虑效率问题)。

    即:

select * from content where tags like "%2%";

    问题:显而易见的是我们这样是错误的,因为会把tags中存在22的记录也会查找出来。

    解决方法:没有什么好的办法,只能在insert时插入类似,1,11,3,23,2,(两边加分隔符)这种的字符串,再通过:

select * from content where tags like "%,2,%";

方法二

    其实根本不需要这么麻烦,因为这种常见的问题mysql官方就给出了解决方案,即函数find_ind_set。

    即:

select * from content where find_in_set(2,tags);

方法三

    还有一种方法就是采用全文搜索match against

    即:

select * from content  where match(tags) against('2' in boolean mode);

    注意:

        1.这种方法必须给字段tags添加全文索引;

        2.MySQL5.6之前innoDb不支持全文索引,需要改为myisam;

对比分析:

    既然有了三种方法,我们当然要比较一下优劣喽。

    我在本地用一个200w+的表来做的测试,发现总体上来说

    速度上:方法三 > 方法二 > 方法一,大概相差都是1/3左右。

    感想:这个函数的发现充分的展示了自己对mysql的生疏,一个程序员对数据库的深入了解是必不可少的,包括各种原生函数和各种索引的应用,往往使人事半功倍。

最后,欢迎大家对比测试,评论区见!

    

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
可以使用Spring Data JPA的@Query注解和自定义查询语句来实现。 假设有一个实体类User,其中有两个属性id和name,需要获取所有用户的id并存储一个数组中,可以按照以下步骤操作: 1. 在UserRepository接口中定义一个自定义的查询方法,使用@Query注解指定查询语句,例如: ```java public interface UserRepository extends JpaRepository<User, Long> { @Query("SELECT u.id FROM User u") List<Long> findAllIds(); } ``` 2. 在需要使用的地方注入UserRepository,并调用findAllIds方法获取所有id,例如: ```java @Service public class UserService { @Autowired private UserRepository userRepository; public void getAllIds() { List<Long> ids = userRepository.findAllIds(); // 对ids进行处理 } } ``` 在以上代码中,findAllIds方法返回的是一个包含所有id的List集合,可以根据实际需要进行处理。 如果需要获取多个字段多个数据,只需在查询语句中选择需要的字段即可。例如,如果需要获取所有用户的id和name并存储一个Map中,可以按照以下方式修改查询语句: ```java @Query("SELECT u.id, u.name FROM User u") List<Object[]> findAllIdsAndNames(); ``` 返回的List中每个元素都是一个包含id和name的Object数组,可以使用Map来存储: ```java public void getAllIdsAndNames() { List<Object[]> results = userRepository.findAllIdsAndNames(); Map<Long, String> idNameMap = new HashMap<>(); for (Object[] result : results) { Long id = (Long) result[0]; String name = (String) result[1]; idNameMap.put(id, name); } // 对idNameMap进行处理 } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值