sql中字符串匹配问题
先上数据示例
ID | cat_id |
---|---|
1 | 1,2,4 |
2 | 2,3 |
3 | 11,13,17,19 |
4 | 3,7,9,12 |
这是某多对多关系在基于mysql的数据表中的表现形式(因为上头说应用小用两个表就算了)
并且筛选查询的要求如下表
推送条件 | 期望结果(ID) |
---|---|
1 | 1 |
1,2 | 1 |
1,3 | null |
3,9 | 4 |
3 | 2,4 |
注:推送条件和期望结果都是以
,
隔开,实际上是个一维索引数组
推送条件之间是AND
关系
目前鄙人想到的基于thinkphp
的解决方案是:
1.遍历查询结果,将cat_id化为数组
2.判断推送条件(数组形式,可以认为就是表单POST来的一维数组)是不是cat_id数组的子集。
然而问题就在遍历查询结果,这里测试是:结果如果达到6000+条,执行时间需要3~20秒左右,比较慢。
于是问一下,上表这样的筛选要求能不能用sql语句实现,从而省掉遍历的过程?
回复内容:
先上数据示例
ID | cat_id |
---|---|
1 | 1,2,4 |
2 | 2,3 |
3 | 11,13,17,19 |
4 | 3,7,9,12 |
这是某多对多关系在基于mysql的数据表中的表现形式(因为上头说应用小用两个表就算了)
并且筛选查询的要求如下表
推送条件 | 期望结果(ID) |
---|---|
1 | 1 |
1,2 | 1 |
1,3 | null |
3,9 | 4 |
3 | 2,4 |
注:推送条件和期望结果都是以
,
隔开,实际上是个一维索引数组
推送条件之间是AND
关系
目前鄙人想到的基于thinkphp
的解决方案是:
1.遍历查询结果,将cat_id化为数组
2.判断推送条件(数组形式,可以认为就是表单POST来的一维数组)是不是cat_id数组的子集。
然而问题就在遍历查询结果,这里测试是:结果如果达到6000+条,执行时间需要3~20秒左右,比较慢。
于是问一下,上表这样的筛选要求能不能用sql语句实现,从而省掉遍历的过程?
个人感觉,应该可以用sql语句实现,可以写几个存储函数,但这样一来,估计工作量上可能比多加个中间表要困难许多,而且速度上估计也快不了,建议还是建个中间表
这种集合的问题交给 redis
来做最方便不过了
127.0.0.1:6379> SADD cid_1 1
127.0.0.1:6379> SADD cid_2 1
127.0.0.1:6379> SADD cid_2 2
127.0.0.1:6379> SADD cid_3 2
127.0.0.1:6379> SADD cid_4 1
127.0.0.1:6379> SINTER cid_1 cid_2
1) "1"
127.0.0.1:6379> sinter cid_2 cid_3
1) "2"
首先谢谢大家热心的回答
然后最后采取的方案是,将关系表和其中一个存储数据比较少的简单表合并,并在此基础上用两个id区分
具体是模仿了无限子级菜单的那种建表方式

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

在MySQL中,外键的作用是建立表与表之间的关系,确保数据的一致性和完整性。外键通过引用完整性检查和级联操作维护数据的有效性,使用时需注意性能优化和避免常见错误。

MySQL和MariaDB的主要区别在于性能、功能和许可证:1.MySQL由Oracle开发,MariaDB是其分支。2.MariaDB在高负载环境中性能可能更好。3.MariaDB提供了更多的存储引擎和功能。4.MySQL采用双重许可证,MariaDB完全开源。选择时应考虑现有基础设施、性能需求、功能需求和许可证成本。

多次调用session_start()会导致警告信息和可能的数据覆盖。1)PHP会发出警告,提示session已启动。2)可能导致session数据意外覆盖。3)使用session_status()检查session状态,避免重复调用。

MySQL和phpMyAdmin可以通过以下步骤进行有效管理:1.创建和删除数据库:在phpMyAdmin中点击几下即可完成。2.管理表:可以创建表、修改结构、添加索引。3.数据操作:支持插入、更新、删除数据和执行SQL查询。4.导入导出数据:支持SQL、CSV、XML等格式。5.优化和监控:使用OPTIMIZETABLE命令优化表,并利用查询分析器和监控工具解决性能问题。

AI可以帮助优化Composer的使用,具体方法包括:1.依赖管理优化:AI分析依赖关系,建议最佳版本组合,减少冲突。2.自动化代码生成:AI生成符合最佳实践的composer.json文件。3.代码质量提升:AI检测潜在问题,提供优化建议,提高代码质量。这些方法通过机器学习和自然语言处理技术实现,帮助开发者提高效率和代码质量。

在MySQL中,添加字段使用ALTERTABLEtable_nameADDCOLUMNnew_columnVARCHAR(255)AFTERexisting_column,删除字段使用ALTERTABLEtable_nameDROPCOLUMNcolumn_to_drop。添加字段时,需指定位置以优化查询性能和数据结构;删除字段前需确认操作不可逆;使用在线DDL、备份数据、测试环境和低负载时间段修改表结构是性能优化和最佳实践。

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。

要安全、彻底地卸载MySQL并清理所有残留文件,需遵循以下步骤:1.停止MySQL服务;2.卸载MySQL软件包;3.清理配置文件和数据目录;4.验证卸载是否彻底。
