【问题标题】:How to find the character in nth position in a string如何在字符串中找到第n个位置的字符
【发布时间】:2014-07-23 10:20:02
【问题描述】:

例如,

create table tblvarchar 
(
lngvarchar character varying(500)
)

样本行是

insert into tblvarchar (lngvarchar) values ('110010000001111101010011110000001101011000001')
  • 如何使用character的位置找出lngvarchar字段中的character(本例(01))?
  • 例如lngvarchar第15位的character1

在 PostgreSQL 9.2.4 上

【问题讨论】:

    标签: postgresql postgresql-9.2 string-function


    【解决方案1】:

    您可以这样做(起始位置 15,长度 1 示例):

    SELECT SUBSTRING(lngvarchar,15,1) FROM tblvarchar;
    

    SQL FIDDLE

    【讨论】:

      【解决方案2】:

      如果您的数据仅包含01,您可能希望使用bit strings 而不是character varying(在您的情况下为bit varying)。

      您可以使用get_bit() 函数获取单个位(但该函数使用从零开始的索引); substring() 也适用于位字符串(但会给你text 结果)。

      SQLFiddle

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2011-04-27
        • 1970-01-01
        • 2019-09-22
        • 2018-11-01
        • 2018-12-23
        • 2017-03-26
        相关资源
        最近更新 更多