PHP数据库SQL插入

PHP数据库SQL插入,php,mysql,sql-server,database,sql-insert,Php,Mysql,Sql Server,Database,Sql Insert,我正在尝试将数据从我的应用程序写入外部数据库。 我只是在PHP页面上没有得到任何响应。当我查看发送到PHP页面的变量时,它们收到的效果良好,此时没有出现任何问题。 但是,当我使用SQL进行插入时,它会出错。(我想)。 当我进入我的PHPadmin页面并执行下一个SQL命令时,它会起作用: INSERT INTO images (FBid,Datum,Lat,Longi,Image) VALUES ('1846465164', '2016-08-25 14:14:15',10.5,5.69,'/

我正在尝试将数据从我的应用程序写入外部数据库。 我只是在PHP页面上没有得到任何响应。当我查看发送到PHP页面的变量时,它们收到的效果良好,此时没有出现任何问题。 但是,当我使用SQL进行插入时,它会出错。(我想)。 当我进入我的PHPadmin页面并执行下一个SQL命令时,它会起作用:

INSERT INTO images (FBid,Datum,Lat,Longi,Image) 
VALUES ('1846465164',
'2016-08-25 14:14:15',10.5,5.69,'/9j/
 4AAQSkZJRgABAQAAAQABAAD/2wBDAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQE
 BAQEBQBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQH/2wBDAQEBAQEBAQEBAQEBAQEBAQEBAQEB')
所以我有下一个数据库

ID(PRIMARY KEY AUTOINCREMENT), 
FBid (varchar(255)), 
Datum (datetime), 
Lat (Double), 
Longi(Double), 
Image(Blob).
这是我的php页面:

<?php



 if($_SERVER['REQUEST_METHOD']=='POST'){

   define('HOST','localhost');
 define('USER','XXXXXXXXX');
 define('PASS','XXXXXXXXX');
 define('DB','database2');

 $con = mysqli_connect(HOST,USER,PASS,DB) or die('Unable to Connect');

 $image = $_POST['image'];
 $FBid = $_POST['FBid'];
 $date = $_POST['Date'];
 $long = $_POST['long'];
 $lat = $_POST['lat'];

 $stmt = $con->prepare(
                "INSERT INTO images (FBid,Datum,Lat,Longi,Image) 
                 VALUES (:Fbid,:date,:lat,:long,:image)"); 
        $stmt->bindParam(":Fbid",$FBid);
        $stmt->bindParam(":date", $date);
        $stmt->bindParam(":lat", $lat);
        $stmt->bindParam(":long", $long);
        $stmt->bindParam(":image","s",$image);
        $stmt->execute();

$check = mysqli_stmt_affected_rows($stmt);

 if($check == 1){
 echo "Image Uploaded Successfully";
 }else{
 echo "Error Uploading Image";
 }
 mysqli_close($con);
 }else{
 echo "Error";
 }

查看数据库连接,您使用错误。在INSERT语句中,它看起来像PDO版本。如果您想使用PDO版本,请看一下这个。你不能把PDO和mysqli混在一起。mysqli_prepare的程序风格如下:

$stmt = mysqli_prepare($con, "INSERT INTO images VALUES (?, ?, ?, ?, ?)");
if ( !$stmt ) {
   die('mysqli error: '.mysqli_error($con);
}
mysqli_stmt_bind_param($stmt, 'ssddb', $FBid,$date,$lat,$long,$image);
if ( !mysqli_stmt_execute($stmt)) {
   die( 'stmt error: '.mysqli_stmt_error($stmt) );
}

$check = mysqli_stmt_affected_rows($stmt);
if($check == 1){
 echo 'Image successfully uploaded';
}else{
 echo 'Error uploading image';
}
mysqli_stmt_close($stmt);

查看数据库连接,您使用的是错误的。在INSERT语句中,它看起来像PDO版本。如果您想使用PDO版本,请看一下这个。你不能把PDO和mysqli混在一起。mysqli_prepare的程序风格如下:

$stmt = mysqli_prepare($con, "INSERT INTO images VALUES (?, ?, ?, ?, ?)");
if ( !$stmt ) {
   die('mysqli error: '.mysqli_error($con);
}
mysqli_stmt_bind_param($stmt, 'ssddb', $FBid,$date,$lat,$long,$image);
if ( !mysqli_stmt_execute($stmt)) {
   die( 'stmt error: '.mysqli_stmt_error($stmt) );
}

$check = mysqli_stmt_affected_rows($stmt);
if($check == 1){
 echo 'Image successfully uploaded';
}else{
 echo 'Error uploading image';
}
mysqli_stmt_close($stmt);


这看起来像PDO代码,而不是mysqli。你确定那是对的吗?此外,如果只使用一次,则无需创建中间变量,如
$FBid
。只需将
$\u POST
数据直接放在
bindParam
调用中。图像参数中不应该有“s”binding@tadman我删除了“mysqli”,但没有区别。创建变量有什么问题?@PhiterFernandes我删除了“s”仍然没有区别。如果你想使用命名占位符,这是个好主意,请使用PDO
mysqli
不支持它们。这看起来像PDO代码,而不是
mysqli
。你确定那是对的吗?此外,如果只使用一次,则无需创建中间变量,如
$FBid
。只需将
$\u POST
数据直接放在
bindParam
调用中。图像参数中不应该有“s”binding@tadman我删除了“mysqli”,但没有区别。创建变量有什么问题?@PhiterFernandes我删除了“s”仍然没有区别。如果你想使用命名占位符,这是个好主意,请使用PDO
mysqli
不支持它们。感谢您的回答,但它仍然不起作用。我把它改成你说的。当我在bind_参数之前添加echo时,是get the echo,。我的位置在绑定参数后面,我没有收到回声。我觉得那里出了点问题。我还重复了所有矿山变量,它们看起来是这样的:$FBid=15325244$date=2015-08-2514:14:14$lat=100.02$long=100.6$image=/9j/。。。。。。所以我想没问题。我更新了我的答案。添加mysqli_stmt_execute($stmt);没有变化。我在注释中放置了第一个if,以检查在浏览器中打开页面时是否存在任何错误。当我在浏览器中打开它时,我得到以下警告:警告:mysqli_stmt_bind_param()希望参数1是mysqli_stmt,布尔值在/home/jail/home/sbosmans2/public_html/Android_app_server/upload.php第18行中给出。您是否尝试过我的答案的更新版本?我找到了解决方案!因为在我的表中有一个自动递增列。我需要添加一个“null”值$stmt=mysqli_prepare($con,“插入到图像中的值(null、、、、、、、?)”);谢谢!:)谢谢你的回答,但还是不行。我把它改成你说的。当我在bind_参数之前添加echo时,是get the echo,。我的位置在绑定参数后面,我没有收到回声。我觉得那里出了点问题。我还重复了所有矿山变量,它们看起来是这样的:$FBid=15325244$date=2015-08-2514:14:14$lat=100.02$long=100.6$image=/9j/。。。。。。所以我想没问题。我更新了我的答案。添加mysqli_stmt_execute($stmt);没有变化。我在注释中放置了第一个if,以检查在浏览器中打开页面时是否存在任何错误。当我在浏览器中打开它时,我得到以下警告:警告:mysqli_stmt_bind_param()希望参数1是mysqli_stmt,布尔值在/home/jail/home/sbosmans2/public_html/Android_app_server/upload.php第18行中给出。您是否尝试过我的答案的更新版本?我找到了解决方案!因为在我的表中有一个自动递增列。我需要添加一个“null”值$stmt=mysqli_prepare($con,“插入到图像中的值(null、、、、、、、?)”);谢谢!:)