请问php mysql select支持explode字段然后根据值排序吗?
1.例如表里某字段格式如下:数据1|||||数据2|||||数据3
2.现在想要把数据分割成$data[0],$data[1],$data[3],然后order by $data[3]
3.请问能实现吗?
4.完全小白,描述可能不规范,但意思应该说明白了。
回复内容:
1.例如表里某字段格式如下:数据1|||||数据2|||||数据3
2.现在想要把数据分割成$data[0],$data[1],$data[3],然后order by $data[3]
3.请问能实现吗?
4.完全小白,描述可能不规范,但意思应该说明白了。
能实现,如果在MySQL层面实现可能会导致数据库压力比较大.
可以考虑在PHP程序这边排好序,然后再根据ID序列从MySQL取数据.
<code><?php header('Content-Type: text/plain; charset=utf-8'); //$db = new mysqli('127.0.0.1','user','pass','dbname',3306); //$arr = $db->query('SELECT id,field FROM table')->fetch_all(MYSQLI_ASSOC); //假设取出来的数据结构如下 $arr = array( array('id' => 1, 'field' => '数据1|||||数据2|||||256'), array('id' => 2, 'field' => '数据1|||||数据2|||||128'), array('id' => 3, 'field' => '数据1|||||数据2|||||512'), ); foreach($arr as $k => $v) { //把field字段的内容转成一个数组比如array('数据1','数据2','256'),方便后面排序 $arr[$k]['field'] = explode('|||||', $v['field']); } //根据field字段里的第三个元素对数组进行排序 uasort($arr, function($a, $b) { if($a['field'][2]===$b['field'][2]) return 0; //下面这句话的意思就是,如果前面的a大过后面的b,就返回1,返回1表示交换顺序,也就是小的数在前面,由小到大升序排列. else return ($a['field'][2] > $b['field'][2]) ? 1 : -1; }); foreach($arr as $k => $v) { $ids[] = $v['id']; } $ids = implode(',', $ids); //ID序列为2,1,3 //按照ID序列的顺序查询MySQL //SQL语句为 SELECT * FROM table WHERE id IN(2,1,3) ORDER BY FIELD(id,2,1,3) $sql = "SELECT * FROM table WHERE id IN($ids) ORDER BY FIELD(id,$ids)"; //$ret = $db->query($sql)->fetch_all();</code>
如果数据量很大,可以考虑把PHP排好的ID序列缓存起来.
ORDER BY FIELD(id,$ids) 这个操作在数据量大时也会产生性能问题,
这时可以考虑根据实际情况对$ids进行切分,比如第一页0到19排序20条,第二页类推,这样小数据量的自定义排序对MySQL压力就小得多了.
这个和php没什么关系。你可以用mysql创建一个function,然后用function来排序:
<code>CREATE FUNCTION SPLIT_STRING(str VARCHAR(255), delim VARCHAR(12), pos INT) RETURNS VARCHAR(255) RETURN REPLACE(SUBSTRING(SUBSTRING_INDEX(str, delim, pos), LENGTH(SUBSTRING_INDEX(str, delim, pos-1)) + 1), delim, '');</code>
<code>SELECT * FROM test_table order by SPLIT_STRING(test_tablecol, '|||', 3);</code>
能实现,很麻烦,而且效率非常低,对于这种要求通常的解决办法是修改表结构。
从纯逻辑上来说,sql其实可以做很复杂的事情,但是你觉得如果一个查询需要跑好几分钟的话被家里人知道了会不会挨打?
建议查询出来之后用php排序,不要用mysql排序
mysql 的substring_index

热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和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.验证卸载是否彻底。

MySQL批量插入数据的高效方法包括:1.使用INSERTINTO...VALUES语法,2.利用LOADDATAINFILE命令,3.使用事务处理,4.调整批量大小,5.禁用索引,6.使用INSERTIGNORE或INSERT...ONDUPLICATEKEYUPDATE,这些方法能显着提升数据库操作效率。

MySQL函数可用于数据处理和计算。1.基本用法包括字符串处理、日期计算和数学运算。2.高级用法涉及结合多个函数实现复杂操作。3.性能优化需避免在WHERE子句中使用函数,并使用GROUPBY和临时表。

在MySQL中配置字符集和排序规则的方法包括:1.设置服务器级别的字符集和排序规则:SETNAMES'utf8';SETCHARACTERSETutf8;SETCOLLATION_CONNECTION='utf8_general_ci';2.创建使用特定字符集和排序规则的数据库:CREATEDATABASEexample_dbCHARACTERSETutf8COLLATEutf8_general_ci;3.创建表时指定字符集和排序规则:CREATETABLEexample_table(idINT
