SQL Server - 选择列描述中给出范围的列

 mobiledu2502860153 发布于 2023-02-12 15:21

如果我做得对:

WHERE 
CAST(SUBSTRING(Description,3,CHARINDEX('K',Description)-3) AS INT)
BETWEEN 10 and 40

SQL Fiddle demo

假设您对此答案的评论没有修复第一个位置,所以在这种情况下您应该在MSSQL中使用PATINDEX()函数:

WHERE 
    CAST(SUBSTRING(Description,
                    PATINDEX('%[0-9]%',Description), 
                    PATINDEX('%[0-9]K%',Description)-
                    PATINDEX('%[0-9]%',Description)+1)
         AS INT)
      BETWEEN 10 and 40

SQLFiddle demo

1 个回答
  • 如果我做得对:

    WHERE 
    CAST(SUBSTRING(Description,3,CHARINDEX('K',Description)-3) AS INT)
    BETWEEN 10 and 40
    

    SQL Fiddle demo

    假设您对此答案的评论没有修复第一个位置,所以在这种情况下您应该在MSSQL中使用PATINDEX()函数:

    WHERE 
        CAST(SUBSTRING(Description,
                        PATINDEX('%[0-9]%',Description), 
                        PATINDEX('%[0-9]K%',Description)-
                        PATINDEX('%[0-9]%',Description)+1)
             AS INT)
          BETWEEN 10 and 40
    

    SQLFiddle demo

    2023-02-12 15:25 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有