为什么sql过长会执行失败,举一个案例

为什么sql过长会执行失败,举一个案例,第1张

1、不同的数据库应该是不一样的

2、不过任何东西不可能完全没有限制,所以sql过长会失败是肯定的。

3、以Mysql为例,在其配置文件中有一个设置 max_allowed_packet = 1M 此时如果你的SQL长度超过了1M就会被截断,从而导致执行失败。

Count: 6 Time=25.33s (152s) Lock=0.00s (0s) Rows=0.0 (0), xxx[xxx]@xxx

INSERT INTO tablename(f_uid,uid,create_time) VALUES (N,N,N)

分析原因如下:

1.不可能是锁等待,因为记录的Lock时间为0;

2.若是InnoDB引擎,则跟主键为啥存在一定关系,但是应该不是特别大,从你的SQL语句看;

3.数据库主机的负载过高,导致处理不过,是最可能的原因;

一般碰到这么长的语句,容易出错,通用都用一个"变通"的写法,

mysql="SELECT [字段0] From [数据表1] WHERE "

mysql = mysqlr &"[字段1]='" &DataGrid1.Columns(0).Text &"' and [字段2]='" &DataGrid1.Columns(1).Text &"' and [字段3]='" &DataGrid1.Columns(2).Text &"' and "

mysql=mysql &"[字段4]='" &DataGrid1.Columns(3).Text &"' and [字段5]='" &DataGrid1.Columns(4).Text &"' and [字段6]='" &DataGrid1.Columns(5).Text &"' and"

........

以此类推,直至到最后


欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/zaji/6105076.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-14
下一篇 2023-03-14

发表评论

登录后才能评论

评论列表(0条)

保存