GaussDB(DWS)字符串处理函数返回错误结果集排查

摘要:在使用字符串处理函数时,有时会出现非预期结果的场景。在排除使用问题后,应该从encoding和数据本身开始排查。

本文分享自华为云社区《GaussDB(DWS)字符串处理函数返回错误结果集排查》,作者: -CHEN111- 。

在使用字符串处理函数时,有时会出现非预期结果的场景。在排除使用问题后,应该从encoding和数据本身开始排查。

直接从案例出发。

(一)案例背景

客户执行instr查空格下标,子查询中查询结果与将子查询的结果粘出来单独执行结果集不一致。

SELECT instr((SELECT a FROM t1), ' ') xxxxx; 
SELECT a FROM t1; 的结果是a -> SELECT instr(a, ' ');

假设当前select a from t1;通过数据库连接客户端查询后显示结果集为“测试测 试 测试”

SELECT instr((SELECT a FROM t1), ' '); --结果为6
SELECT instr('测试测 试 测试', ' '); --结果为4

(二)问题排查

从上述结果集中可以看出,如果把SELECT a FROM t1;的结果集单独复制出来,则其结果4为预期结果,而当SELECT a FROM t1;作为子查询进行instr处理时,结果为6是不符合预期的。

排查主要从encoding和子查询结果集入手

1.先判断encoding

不同的编码类型下,字符串处理也不相同。

  • UTF8是按字符算个数
  • SQL_ASCII是按字节算个数

对于“测试测 试 测试”而言,按字符个数计算,SELECT instr('测试测 试 测试', ' ')的结果应为4;按字节个数计算,一个汉字占3个字节,SELECT instr('测试测 试 测试', ' ')的结果应为10。

查看当前库编放码类型

SHOW server_encoding;

结果为UTF8,故预期结果应该为4,但是SELECT instr((SELECT a FROM t1), ' ');结果却为6。

此时开始怀疑是否是客户端查询导致字符串结果集显示错误

2. 子查询结果集排查

通过编解码拿到字符串结果集的十六进制

SELECT encode(a, 'hex') AS res FROM t1;
                   res
------------------------------------------
 e6b58be8af95e6b58b0d0ae8af9520e6b58be8af95
(1 row)

在本地解码后结果集为

SELECT  convert_from(decode('e6b58be8af95e6b58b0d0ae8af9520e6b58be8af95','hex'),'utf8');
 convert_from
--------------
 测试测\r    +
 试 测试

可以看出,字符串结果集中,‘测试测’后并非空格,而是’\r +’。

3. 解决方案

将’\r +'按照编解码的形式替换空格

SELECT instr((SELECT a FROM t1), convert_from(decode('0d0a','hex'),'utf8'));

此时结果为4,为客户预期结果。

 

点击关注,第一时间了解华为云新鲜技术~

原文链接:https://www.cnblogs.com/huaweiyun/p/17377489.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:GaussDB(DWS)字符串处理函数返回错误结果集排查 - Python技术站

(0)
上一篇 2023年5月6日
下一篇 2023年5月6日

相关文章

  • MySQL 8.0.x for Windows 解压缩版配置安装

    一、官网下载MySQL8.0.16 直达官网下载Community版:https://dev.mysql.com/downloads/mysql/然后拉倒下方点击对应版本位数下载   二、创建my.ini 下载完压缩包之后就解压,再创建一个同级空目录mysqlData,再进入mysql8.0.16安装根目录创建一个my.ini配置 [mysqld] # 设置…

    MySQL 2023年4月13日
    00
  • 详解MySQL IS NULL:空值查询

    在MySQL中,IS NULL被用于检测一个列是否为空值。如果列的值是空值,则IS NULL返回TRUE,否则返回FALSE。 下面是MySQL IS NULL语法的一般形式: SELECT column_name(s) FROM table_name WHERE column_name IS NULL; 以下是关于MySQL IS NULL的一些实例: 实…

    MySQL 2023年3月10日
    00
  • MYSQL 表的全面总结

    MYSQL 表的全面总结攻略 什么是MYSQL表 MySQL是一个开放源代码的关系型数据库管理系统(RDBMS),MySQL表是其管理的数据之间的最小单元,它包含了多个列和行,数据存储在行中的各个列中,在操作MySQL数据库时必须要使用表名。 如何创建MYSQL表 创建MySQL表需要使用CREATE TABLE语句。 语法如下: CREATE TABLE …

    MySQL 2023年5月18日
    00
  • 一个 20 秒 SQL 慢查询优化处理方案

    一个 20 秒 SQL 慢查询优化处理方案 1. 确认慢查询 首先要确认该查询是慢查询,可以通过MySQL自带的slow query log来查看,也可以使用一些第三方工具,如pt-query-digest等。确认慢查询后,需要查看该SQL的执行计划,以确定具体的瓶颈和优化方向。 2. 分析执行计划 分析SQL的执行计划可以使用MySQL自带的explain…

    MySQL 2023年5月19日
    00
  • 理解MySQL查询优化处理过程

    为了帮助你更好地理解MySQL查询优化处理过程,我将提供以下攻略。 理解MySQL查询优化处理过程 查询优化处理过程是MySQL中非常重要的一步,它能够提高查询性能,减少数据访问和IO操作。MySQL查询优化处理过程可以被分为以下步骤: 语法解析和预处理。MySQL接收SQL语句,首先会对SQL语句进行语法解析和预处理,确保语句的合法性和正确性。 查询重写。…

    MySQL 2023年5月19日
    00
  • MySQL如何获取binlog的开始时间和结束时间

    MySQL数据库恢复到指定时间点时,我们必须通过MySQL全备+MySQL增量备份(可选)+MySQL的二进制日志(binlog)进行重放来恢复到指定时间点,实际的生产环境中,可能一段时间内生成了多个二进制日志文件(binlog), MySQL本身不会存储二进制日志文件(binlog)的开始时间和结束时间,如果要还原到某个时间点,我们需要知道还原后重放哪些二…

    MySQL 2023年5月6日
    00
  • mysql织梦索引优化之MySQL Order By索引优化

    MySQL Order By 索引优化 在对MySQL数据库进行数据查询时,Order By操作常常需要花费较长时间,因此我们需要对MySQL数据库进行索引优化,减少查询时间的同时,提高查询效率。本文将详细讲解MySQL Order By索引优化的各种情况和方法,以减少数据库查询的时间复杂度。 为什么需要优化MySQL Order By查询语句 Order …

    MySQL 2023年5月19日
    00
  • SQL Server 出现Error: 1326错误(管理器无法连接远程数据库)问题解决方案

    以下是详细讲解“SQL Server 出现Error: 1326错误(管理器无法连接远程数据库)问题解决方案”的完整攻略: 问题描述 在使用SQL Server Management Studio连接SQL Server数据库时,可能会出现Error: 1326错误的情况,无法连接远程数据库。 问题原因 这种错误通常是由于以下原因之一造成的: DNS解析问题…

    MySQL 2023年5月18日
    00
合作推广
合作推广
分享本页
返回顶部