加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – Mysqli准备语句插入不插入

发布时间:2020-12-13 17:47:56 所属栏目:PHP教程 来源:网络整理
导读:我已经连接到数据库了.当我回显所有变量时,它们可以工作,但它们不会插入到我的数据库表中.我的表名正确.这是代码: ?php$pid = '1'; $pname = 'name'; $poster_id = '2';$poster_name = 'name2'; $message = 'This is the message';$datetime = date("M d,Y"
我已经连接到数据库了.当我回显所有变量时,它们可以工作,但它们不会插入到我的数据库表中.我的表名正确.这是代码:

<?php

$pid = '1'; 
$pname = 'name'; 
$poster_id = '2';
$poster_name = 'name2'; 
$message = 'This is the message';

$datetime = date("M d,Y");

// insert into database
$ins  = "INSERT INTO messages (profile_id,profile_name,poster_id,poster_name,message,countnum,postdate) VALUES (?,?,?)";

$stmt = $con->prepare($ins);
$num = 1;
$stmt->bind_param('isissis',$pid,$pname,$user_id,$user,$comment,$num,$datetime);
$stmt->execute();

?>

在此先感谢您的帮助.

解决方法

你有一些不匹配的变量.

$poster_id – $poster_name – $message

在你的绑定中与之对齐:

$user_id,$comment

这应该现在有效:

<?php

$pid = '1'; 
$pname = 'name'; 
$poster_id = '2';
$poster_name = 'name2'; 
$message = 'This is the message';

$datetime = date("M d,$poster_id,$poster_name,$message,$datetime);
$stmt->execute();

?>

但是,你应该替换$stmt-> execute(); with if(!$stmt-> execute()){trigger_error(“有一个错误……”.$con>错误,E_USER_WARNING);}

为了抓住错误.

还要在文件顶部添加error reporting,这有助于查找错误.

<?php 
error_reporting(E_ALL);
ini_set('display_errors',1);

// rest of your code

这将发出一个未定义的变量警告信号.

旁注:错误报告应该只在暂存中完成,而不是生产.

洞察力

正如Ghost所指出的那样:

$datetime格式M d,Y也是可疑的,它可能搞砸Y-m-d H:i:s的格式为DATETIME列,如果确实如此.

因此你可能需要改变

$datetime = date("M d,Y");

$datetime = date("Y-m-d H:i:s");

要么

$datetime = date("Y-m-d");

取决于列类型的设置.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读