搜索
首页后端开发php教程thinkphp插入数据库操作错误

thinkphp MySQL 数据库

thinkphp从excel读取数据插入mysql,生成sql语句正确,单独能执行,用
$model->execute($sql),执行时,凡是字符串都只插入了首字符。生成sql语句是这样 insert into table values('','ABCDEF'),没有列举完,只是举例,单独执行插入成功,在thinkphp里面执行,字符串ABCDEF只插入了一个A。在tp里面打印出最后执行的sql语句也是对的

回复讨论(解决方案)

直接执行也是同样的结果吗?   我本来还以为会是数据库字段类型和长度限制了   要是直接执行也这样  那得追踪到TP的最终mysql_query的地方检察mysql_query之前的$sql

直接执行也是同样的结果吗?   我本来还以为会是数据库字段类型和长度限制了   要是直接执行也这样  那得追踪到TP的最终mysql_query的地方检察mysql_query之前的$sql



能说详细一些吗?谢谢你


直接执行也是同样的结果吗?   我本来还以为会是数据库字段类型和长度限制了   要是直接执行也这样  那得追踪到TP的最终mysql_query的地方检察mysql_query之前的$sql
能说详细一些吗?谢谢你

其实是你这边应该描述的详细一点

没有无解的"灵异问题" 一定是哪里有问题

依我浅见,或者是TP对SQL语句的处理出了问题,或者是mysql的数据结构/类型有问题. 没能想出其他可能

所以先试试手动写SQL语句直接在mysql执行, 看看结果,你现在说插入成功,插入后的结果呢?也是想要的吗?

如果手动插入结果正确 那就在TP框架内顺藤摸瓜找到TP插入mysql的语句 将此时的SQL语句打印出来 看跟你手写的SQL语句是否一致.

然后才好进一步看....


当然,可能有大神遇到过这种问题能一下指出原因 不过在此之前可以先试试这样找找原因

其实是你这边应该描述的详细一点

$res = $order_insert->execute($sql);
echo $order_insert->getLastSql();
在执行execute的时候,$sql是正常的,复制出来单独执行,结果也是想要的。 当执行完,用$order_insert->getLastSql();获取最后一条执行的sql语句,sql语句也是正常的,对这个sql字符串直接复制到execute执行也是能正常插入数据,就是当做参数执行时,出现上面说的情况

你怎么不在当做参数执行时,也看一下 $order_insert->getLastSql() 呢 其实是你这边应该描述的详细一点

$res = $order_insert->execute($sql);
echo $order_insert->getLastSql();
在执行execute的时候,$sql是正常的,复制出来单独执行,结果也是想要的。 当执行完,用$order_insert->getLastSql();获取最后一条执行的sql语句,sql语句也是正常的,对这个sql字符串直接复制到execute执行也是能正常插入数据,就是当做参数执行时,出现上面说的情况


你怎么不在当做参数执行时,也看一下 $order_insert->getLastSql() 呢

看了的,就是把组装出来的sql语句当做参数给execute,然后执行后,再获取最后一条执行的sql语句,打印出来是完整的sql语句  insert into table value('','ABCDEF');这样的语句,但是数据库的表里面对应ABCDEF这个字符只插入了一个字符A

这个会不会是数据库的字段问题啊,直接把sql在mysql执行还会这样?

这个会不会是数据库的字段问题啊,直接把sql在mysql执行还会这样?

不是字段问题哈,直接执行插入是正常的!

已经找到问题,是读取excel的时候,要加一句setOutputEncoding

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
在Laravel中使用Flash会话数据在Laravel中使用Flash会话数据Mar 12, 2025 pm 05:08 PM

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

php中的卷曲:如何在REST API中使用PHP卷曲扩展php中的卷曲:如何在REST API中使用PHP卷曲扩展Mar 14, 2025 am 11:42 AM

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

简化的HTTP响应在Laravel测试中模拟了简化的HTTP响应在Laravel测试中模拟了Mar 12, 2025 pm 05:09 PM

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

在Codecanyon上的12个最佳PHP聊天脚本在Codecanyon上的12个最佳PHP聊天脚本Mar 13, 2025 pm 12:08 PM

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

PHP记录:PHP日志分析的最佳实践PHP记录:PHP日志分析的最佳实践Mar 10, 2025 pm 02:32 PM

PHP日志记录对于监视和调试Web应用程序以及捕获关键事件,错误和运行时行为至关重要。它为系统性能提供了宝贵的见解,有助于识别问题并支持更快的故障排除

解释PHP中晚期静态结合的概念。解释PHP中晚期静态结合的概念。Mar 21, 2025 pm 01:33 PM

文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

自定义/扩展框架:如何添加自定义功能。自定义/扩展框架:如何添加自定义功能。Mar 28, 2025 pm 05:12 PM

本文讨论了将自定义功能添加到框架上,专注于理解体系结构,识别扩展点以及集成和调试的最佳实践。

框架安全功能:防止漏洞。框架安全功能:防止漏洞。Mar 28, 2025 pm 05:11 PM

文章讨论了框架中的基本安全功能,以防止漏洞,包括输入验证,身份验证和常规更新。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器