码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 动态列排序


    【问题】

    I have this data in my table and I want to sort it using the numbers in the data.

    Data unsorted

    5 team team team team

    team team team 2 team

    team team team team 4

    team 1 team team team

    team team 3 team team

    Data Sorted

    team 1 team team team

    team team team 2 team

    team team 3 team team

    team team team team 4

    5 team team team team

    有人给出解答,楼主没回复

    Create this function:

    1. CREATE FUNCTION IsNumeric (val varchar(255)) RETURNS tinyint
    2.  RETURN val REGEXP '^(-|\\+){0,1}([0-9]+\\.[0-9]*|[0-9]*\\.[0-9]+|[0-9]+)$';
    3. CREATE FUNCTION GetNumericOnly (val VARCHAR(255))
    4.  RETURNS VARCHAR(255)
    5. BEGIN
    6.  DECLARE idx INT DEFAULT 0;
    7.  IF ISNULL(val) THEN RETURN NULL; END IF;
    8.  IF LENGTH(val) = 0 THEN RETURN ""; END IF;
    9.  SET idx = LENGTH(val);
    10.   WHILE idx > 0 DO
    11.   IF IsNumeric(SUBSTRING(val,idx,1)) = 0 THEN
    12.    SET val = REPLACE(val,SUBSTRING(val,idx,1),"");
    13.    SET idx = LENGTH(val)+1;
    14.   END IF;
    15.   SET idx = idx - 1;
    16.   END WHILE;
    17.   RETURN val;
    18.  END;

    Then use it like this:

    1. SELECT * FROM mixedvalues
    2. ORDER BY GetNumericOnly(value)

    【回答】

    SQL做这种动态列的运算很不方便,如果没特别要求,建议读出来用SPL来做,把记录转成数组再取了数值类型的字段排序即可,代码简单也易懂:

    A
    1$select * from tb
    2=A1.sort(~.array().select(ifnumber(~)))

    A1:从表tb取数

    A2:将每条记录的字段值转为序列,从该序列中取出数值成员作为A1的排序表达式进行排序

    写好的脚本如何在应用程序中调用,可以参考Java 如何调用 SPL 脚本

     更多动态列的例子可参考Examples of esProc’s Assisting in Dynamic-Column-SQL Computations – Raqsoft Blog

     

  • 相关阅读:
    springboot中如何进行业务层测试事务回滚
    颜色学习总结
    react数据管理之setState与Props
    HBase优化
    什么是Docker容器?(全面了解使用)
    mannose-Biotin|甘露糖-生物素|甘露糖-聚乙二醇-生物素|生物素-PEG-甘露糖
    华清 c++ day7 9月14
    【牛客网-公司真题-前端入门篇】——如何快速上手牛客
    OpenCV CMake VSCode Windows 平台下运行配置及其解决方案
    dolphinscheduler任务莫名重跑
  • 原文地址:https://blog.csdn.net/raqsoft/article/details/127439507
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号