目录
回复讨论(解决方案)
首页 后端开发 php教程 php 里一个sql语句太长,调式时发现sql语句变得不完整了

php 里一个sql语句太长,调式时发现sql语句变得不完整了

Jun 23, 2016 pm 01:56 PM
sql 发现 语句

PHP高手们,帮我解决一个问题吧:
在php里定义了一条sql如下:
$sql = "SELECT * FROM p_info pi LEFT JOIN job j ON j.id = " . $id .
"WHERE pi.requestid = 0
AND ((ifnull(pi.standard_20_ft_container, 0) - ifnull(j.standard_20_ft_container, 0))  AND ((ifnull(pi.standard_40_ft_container, 0) - ifnull(j.standard_40_ft_container, 0))  AND ((ifnull(pi.high_cube_40_ft_container, 0) - ifnull(j.high_cube_40_ft_container, 0))  AND ((ifnull(pi.capacity_head_of_cattle, 0) - ifnull(j.capacity_head_of_cattle, 0))  AND ((ifnull(pi.capacity_head_of_sheep, 0) - ifnull(j.capacity_head_of_sheep, 0))  AND ((ifnull(pi.capacity_other_livestock, 0) - ifnull(j.capacity_other_livestock, 0))  AND ((ifnull(pi.capacity_number_of_horses, 0) - ifnull(j.capacity_number_of_horses, 0))  AND ((ifnull(pi.grain_feed_kg, 0) - ifnull(j.carrying_capacity_kg, 0))  AND ((ifnull(pi.length_cm, 0) - ifnull(j.tray_length_cm, 0))  AND ((ifnull(pi.width_cm, 0) - ifnull(j.tray_width_cm, 0))  AND ((ifnull(pi.height_cm, 0) - ifnull(j.max_load_height_cm, 0))  AND ((ifnull(pi.weight_kg, 0) - ifnull(j.carrying_capacity_kg, 0))  AND to_days(j.home_day1)  AND to_days(str_to_date(pi.date2, '%d/%m/%Y'))  但是查询出的数据为空,调式时发现,传到$query = mysql_query ( $sql );这里的sql语句变成这样了:
SELECT * FROM p_info pi LEFT JOIN job j ON j.id = 734WHERE pi.requestid = 0
AND ((ifnull(pi.standard_20_ft_container, 0) - ifnull(j.standard_20_ft_container, 0))  AND ((ifnull(pi.standard_40_ft_container, 0) - ifnull(j.standard_40_ft_container, 0))  AND ((ifnull(pi.high_cube_40_ft_container, 0) - ifnull(j.high_cube_40_ft_container, 0))  AND ((ifnull(pi.capacity_head_of_cattle, 0) - ifnull(j.capacity_head_of_cattle, 0))  AND ((ifnull(pi.capacity_head_of_sheep, 0) - ifnull(j.capacity_head_of_sheep, 0))  AND ((ifnull(pi.capacity_other_livestock, 0) - ifnull(j.capacity_other_livestock, 0))  AND ((ifnull(pi.capacity_number_of_horses, 0) - ifnull(j.capacity_number_of_horses, 0))  AND ((ifnull(pi.grain_feed_kg, 0) - ifnull(j.carrying_capacity_kg, 0))  AND ((ifnull(pi.length_cm, 0) - ifnull(j.tray_length_cm, 0))  AND ((ifnull(pi.width_cm, 0) - ifnull(j.tray_width_cm, 0))  AND ((ifnull(pi.height_cm, 0) - ifnull(
貌似后面的就被截断了,数据库里运行这个sql是没问题的。但是在这里就有问题,怎么办呢?大家有遇到这样问题吗?


回复讨论(解决方案)

额。。。没见这么长的 sql  你牛 。。。

不就一千多点,应该不会有问题的,可能是你粘错了

建议:
1、数值字段不要 NULL 而是 NOT NULL 
2、用这个查询创建一个视图

额。。。没见这么长的 sql  你牛 。。。


这个不是长啊,你看都是废话,因为数据库不合理,所以我得这么写啊。

不就一千多点,应该不会有问题的,可能是你粘错了

建议:
1、数值字段不要 NULL 而是 NOT NULL 
2、用这个查询创建一个视图


我可是在调试时发现穿进去的字符串不完整啊。这是什么原因呢。是该设置成not null, 但是我是修bug,不能改数据库啊。等我试试视图吧。

不会无缘无故的被截断的,自己仔细调试一下。


额。。。没见这么长的 sql  你牛 。。。


这个不是长啊,你看都是废话,因为数据库不合理,所以我得这么写啊。
好吧,var_dump输出的字符是有限的,你是echo出来的吧,检查哈是不是这两个符号 "  ‘ 拼接没对 


不就一千多点,应该不会有问题的,可能是你粘错了

建议:
1、数值字段不要 NULL 而是 NOT NULL 
2、用这个查询创建一个视图


我可是在调试时发现穿进去的字符串不完整啊。这是什么原因呢。是该设置成not null, 但是我是修bug,不能改数据库啊。等我试试视图吧。

我定义个一字符串变量,赋了一个 sql语句,长度超过1024了。取不全值。哪里可以改进是这个问题,你看看这个链接,有人跟我同样的问题:
http://bbs.phpchina.com/thread-163748-1-1.html

不会无缘无故的被截断的,自己仔细调试一下。


这个就是调试的结果啊。前面是定义一个sql语句,结果传到query()里面就变成后面这样,被截取了,只剩1024个字符。



额。。。没见这么长的 sql  你牛 。。。


这个不是长啊,你看都是废话,因为数据库不合理,所以我得这么写啊。
好吧,var_dump输出的字符是有限的,你是echo出来的吧,检查哈是不是这两个符号 "  ‘ 拼接没对 
不是,不是,那里就是定义了一个sql语句,然后拼接了一个ID,后面是调试时发现那个sql被截取了只剩1024了。

扫第一眼的时候居然没发现中间插了一句中文...

有人跟我同样的问题:http://bbs.phpchina.com/thread-163748-1-1.html

但那个人不是已经说了: 已解决。xdeubg的bug。不影响程序。吗?
你是否也是这样呢?

扫第一眼的时候居然没发现中间插了一句中文...


好吧,是我排版不给力,导致你没看到。

有人跟我同样的问题:http://bbs.phpchina.com/thread-163748-1-1.html

但那个人不是已经说了: 已解决。xdeubg的bug。不影响程序。吗?
你是否也是这样呢?


我把xdebug的配置在php.ini里注释了之后还是不行哎。

就是说,你还是曾使用了 xdebug 的对吧?

php 并不会限制查询串的长度,这一点可从:将一篇文章通过 insert 指令插入到表中,来映证




额。。。没见这么长的 sql  你牛 。。。


这个不是长啊,你看都是废话,因为数据库不合理,所以我得这么写啊。
好吧,var_dump输出的字符是有限的,你是echo出来的吧,检查哈是不是这两个符号 "  ‘ 拼接没对 
不是,不是,那里就是定义了一个sql语句,然后拼接了一个ID,后面是调试时发现那个sql被截取了只剩1024了。

xdubug var_dump 会自动截断 ,不知道echo会不会 ,关了xdebug试试

就是说,你还是曾使用了 xdebug 的对吧?

php 并不会限制查询串的长度,这一点可从:将一篇文章通过 insert 指令插入到表中,来映证


是的哎,曾使用debug调试,但是在php.ini里把调试的配置注释了之后还是不行。

你是查询出来为空还是返回SQL语句错误?你前面说是查出来为空,但截断的SQL应该会报错的,不是应该先确定这一点吗?

LZ是不是 echo 的时候,就剩下这点了??

如果是的话,建议你把这条语句,写到一个表里面。

你是查询出来为空还是返回SQL语句错误?你前面说是查出来为空,但截断的SQL应该会报错的,不是应该先确定这一点吗?


嗨,谢谢啊。这里是查出来为空。但是同样的查询语句查出来是有结果集的。我也觉得它应该会报错。但是我对php不太了解。而且先前的SQL语句在程序里查询是有结果的。可是到navicat下面查询就报错了。所有这也让我很疑惑。

LZ是不是 echo 的时候,就剩下这点了??

如果是的话,建议你把这条语句,写到一个表里面。


你的意思是什么呢?怎么写到一个表里呢?

我知道了,这里是xdebug的bug,调式时只能显示1024字节,但是你把那个sql语句输出的话是全部都有的。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1674
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
Hibernate 框架中 HQL 和 SQL 的区别是什么? Hibernate 框架中 HQL 和 SQL 的区别是什么? Apr 17, 2024 pm 02:57 PM

HQL和SQL在Hibernate框架中进行比较:HQL(1.面向对象语法,2.数据库无关的查询,3.类型安全),而SQL直接操作数据库(1.与数据库无关的标准,2.可执行复杂查询和数据操作)。

Oracle SQL中除法运算的用法 Oracle SQL中除法运算的用法 Mar 10, 2024 pm 03:06 PM

《OracleSQL中除法运算的用法》在OracleSQL中,除法运算是常见的数学运算之一。在数据查询和处理过程中,除法运算可以帮助我们计算字段之间的比例或者得出特定数值的逻辑关系。本文将介绍OracleSQL中除法运算的用法,并提供具体的代码示例。一、OracleSQL中除法运算的两种方式在OracleSQL中,除法运算可以使用两种不同的方式进行

Oracle和DB2的SQL语法比较与区别 Oracle和DB2的SQL语法比较与区别 Mar 11, 2024 pm 12:09 PM

Oracle和DB2是两个常用的关系型数据库管理系统,它们都有自己独特的SQL语法和特点。本文将针对Oracle和DB2的SQL语法进行比较与区别,并提供具体的代码示例。数据库连接在Oracle中,使用以下语句连接数据库:CONNECTusername/password@database而在DB2中,连接数据库的语句如下:CONNECTTOdataba

详解MyBatis动态SQL标签中的Set标签功能 详解MyBatis动态SQL标签中的Set标签功能 Feb 26, 2024 pm 07:48 PM

MyBatis动态SQL标签解读:Set标签用法详解MyBatis是一个优秀的持久层框架,它提供了丰富的动态SQL标签,可以灵活地构建数据库操作语句。其中,Set标签是用于生成UPDATE语句中SET子句的标签,在更新操作中非常常用。本文将详细解读MyBatis中Set标签的用法,以及通过具体的代码示例来演示其功能。什么是Set标签Set标签用于MyBati

SQL中的identity属性是什么意思? SQL中的identity属性是什么意思? Feb 19, 2024 am 11:24 AM

SQL中的Identity是什么,需要具体代码示例在SQL中,Identity是一种用于生成自增数字的特殊数据类型,它常用于唯一标识表中的每一行数据。Identity列通常与主键列配合使用,可以确保每条记录都有一个独一无二的标识符。本文将详细介绍Identity的使用方式以及一些实际的代码示例。Identity的基本使用方式在创建表时,可以使用Identit

SQL出现5120错误怎么解决 SQL出现5120错误怎么解决 Mar 06, 2024 pm 04:33 PM

解决办法:1、检查登录用户是否具有足够的权限来访问或操作该数据库,确保该用户具有正确的权限;2、检查SQL Server服务的帐户是否具有访问指定文件或文件夹的权限,确保该帐户具有足够的权限来读取和写入该文件或文件夹;3、检查指定的数据库文件是否已被其他进程打开或锁定,尝试关闭或释放该文件,并重新运行查询;4、尝试以管理员身份运行Management Studio等等。

如何使用SQL语句在MySQL中进行数据聚合和统计? 如何使用SQL语句在MySQL中进行数据聚合和统计? Dec 17, 2023 am 08:41 AM

如何使用SQL语句在MySQL中进行数据聚合和统计?在进行数据分析和统计时,数据聚合和统计是非常重要的步骤。MySQL作为一个功能强大的关系型数据库管理系统,提供了丰富的聚合和统计函数,可以很方便地进行数据聚合和统计操作。本文将介绍使用SQL语句在MySQL中进行数据聚合和统计的方法,并提供具体的代码示例。一、使用COUNT函数进行计数COUNT函数是最常用

SQL中months_between如何使用 SQL中months_between如何使用 Jan 25, 2024 pm 03:23 PM

SQL中MONTHS_BETWEEN是一个常见的函数,用于计算两个日期之间的月份差。它的使用方法取决于具体的数据库管理系统。

See all articles