腾讯云TDSQL数据库使用问题总结

本文探讨了执行子查询时遇到的错误,涉及proxy临时表索引长度限制问题。提供了解决方案,包括减少索引字段、使用limit、以及利用TDSQL透传SQL避免代理。注意跨分片数据查询在使用TDSQL时的挑战。
摘要由CSDN通过智能技术生成

1、执行子查询报错

例:

查询sql:select ID from biz_customer where id in( select id from biz_customer where CUSTOMER_NO='1160455829036001000' )

报错内容:
失败原因:ERROR 913 (HY000): Proxy ERROR:Join internal error: Incorrect key file for table 'ay/data/instance_24786_embedded_mysql_p9279/data/tk_core/T56.MYI'; try to repair it [18044c9c7984][913] [3a78d004-c4d7-1a56-82ee-18044c9c7984]

官方回复:

proxy临时表的索引长度超过3000的限制导致的,建议索引不要超过这个限制。

解决方案:

一、官方回答

这个查询用到了proxy的临时表,临时表用的MyISAM引擎的限制,如果查询没用到是不会有这个问题,这里建议的方案是:1.减少索引字段的数量或长度,比如用limit限制。2 优化一下查询

二、个人解决方案

使用TDSQL的透传 SQL功能,不通过proxy代理

说明文档:TDSQL MySQL版 透传 SQL - 开发指南 - 文档中心 - 腾讯云

但这样每个分片只统计自己分片上的数据,相当于把TDSQL当成了一个个独立的mysql去看待,这就需要保证所查询的数据不会跨分片。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值