【问题标题】:SQL - returns a part of a field [duplicate]SQL - 返回字段的一部分[重复]
【发布时间】:2012-12-26 02:36:24
【问题描述】:

可能重复:
Split string in SQL

我在数据库中有一个名为LastName 的列,它具有以下值:

Johnson  (Ext. 12345)

我只想返回不带扩展名的姓氏。

知道在 T-SQL 中使用什么命令吗? (适用于 SSRS 2008 版本)

谢谢

【问题讨论】:

  • 姓氏在左括号前是否总是有空格?
  • 是的,它总是有一个空格

标签: sql sql-server-2008 tsql reporting-services ssrs-2008


【解决方案1】:

试试看,

SELECT RTRIM(SUBSTRING(LastName, 1, CHARINDEX('(', LAstName) - 1)) LastName
FROM table1

【讨论】:

    【解决方案2】:

    你可以;

    left(fld, charindex(' ', fld + ' ', 1) - 1)
    

    【讨论】:

      【解决方案3】:

      首先请允许我说,单个字段中的此类复合值不利于规范化,会出现有关数据完整性、重复性等的各种问题,并且还会在您尝试执行的简单查询中出现问题。

      如果可以的话,您应该将姓氏和分机分成两个不同的列。

      如需回答您的问题,请查看this

      【讨论】:

      • 是的,但命名约定因文化而异。有些人有四个、五个六个或更多的名字:多少列才够?
      • 好吧,如果您不知道要关联的列数,您可以采取不同的方法,您可以将这些值保留为不同表的行,并通过外部关联它们键,其中主表上的一行可以与辅助表上的许多行相关联。但这只是一种方法,根据领域的不同,可以有多种解决方案。
      猜你喜欢
      • 1970-01-01
      • 2014-01-20
      • 1970-01-01
      • 1970-01-01
      • 2022-01-01
      • 2017-03-22
      • 2014-12-12
      • 2018-03-02
      • 2015-10-06
      相关资源
      最近更新 更多