可用版本:Dev3.21)| 最新(3.20)

POSITION (二进制)

适用于 ✅ 开源版   ✅ 专业版   ✅ 企业版

POSITION() 函数查找一个二进制字符串在另一个二进制字符串中首次出现的位置,从 1 开始。

SELECT
  position(cast('hello' as bytea), cast('e' as bytea)),
  position(cast('hello' as bytea), cast('l' as bytea), 4);
create.select(
  binaryPosition("hello".getBytes(), "e".getBytes()),
  binaryPosition("hello".getBytes(), "e".getBytes(), 4)).fetch();

结果是

+----------+----------+
| position | position |
+----------+----------+
|        2 |        4 |
+----------+----------+
有关此函数的文本版本,请参阅 POSITION

方言支持

此示例使用 jOOQ

binaryPosition("hello".getBytes(), "e".getBytes())

翻译成以下特定方言的表达式

Aurora Postgres、CockroachDB、Postgres、YugabyteDB

position(CAST(E'\\145' AS bytea) IN CAST(E'\\150\\145\\154\\154\\157' AS bytea))

Databricks

position(X'65' IN X'68656C6C6F')

Redshift

position(from_hex('65') IN from_hex('68656C6C6F'))

ASE、Access、Aurora MySQL、BigQuery、ClickHouse、DB2、Derby、DuckDB、Exasol、Firebird、H2、HSQLDB、Hana、Informix、MariaDB、MemSQL、MySQL、Oracle、SQLDataWarehouse、SQLServer、SQLite、Snowflake、Sybase、Teradata、Trino、Vertica

/* UNSUPPORTED */
使用 jOOQ 3.21 生成。早期 jOOQ 版本的支持可能有所不同。 在我们的网站上翻译您自己的 SQL

引用此页

反馈

您对此页面有任何反馈吗? 我们很乐意听到您的反馈!

The jOOQ Logo