php - 如何使用 php 更新 sql 中的图像

标签 php mysql image session sql-update

我想更新或设置特定用户的照片,当我尝试上传图像时,图像未上传到我的文件夹“上传”和照片名称(是一个数字,但不是 0,例如:1 .jpg)已插入数据库中,并且数据库中缺少文件扩展名有人可以帮我解决这个问题

这是我的代码:

<?php
session_start();
include("../db_connection.php");

$seller_id = $_SESSION['seller_id'];
$trade_name = $_POST ['trade_name'];
$s_address = $_POST ['s_address'];
$opening_time = $_POST ['opening_time'];
$opening_days = $_POST ['opening_days'];
$order_cutoff = $_POST ['order_cutoff'];
$seller_delivery_time = $_POST ['seller_delivery_time'];
$area_covered_delivery = $_POST ['area_covered_delivery'];
$delivery_fee = $_POST ['delivery_fee'];

 $extension = pathinfo($_FILES['s_image']['name'], PATHINFO_EXTENSION);

$sql = mysqli_query($db, "UPDATE selling_details
                   SET
                   opening_time = '$opening_time',
                   opening_days = '$opening_days',
                   order_cutoff = '$order_cutoff',
                   seller_delivery_time = '$seller_delivery_time',
                   area_covered_delivery = '$area_covered_delivery',
                   delivery_fee = '$delivery_fee'
                   WHERE seller_id= '" . $_SESSION['seller_id'] . "' ");
            if ($sql)
    {
        $id = mysqli_insert_id($db);
        $filename = $id.'.'.$extension;

        if(move_uploaded_file($_FILES['s_image']['tmp_name'], 'upload/'.$filename))
        {
    }
    else
    {
        echo "error occured : " . mysqli_error($db);
    }

$sql2 = mysqli_query($db, "UPDATE seller
                   SET
                   trade_name = '$trade_name',
                   s_address = '$s_address',
                   s_image = '$filename' 
                   WHERE seller_id= '" . $_SESSION['seller_id'] . "' ");
            if ($sql2)
    {

        header('location: seller_menu.php');
    }
    else
    {
        echo "error occured : " . mysqli_error($db);
    }
    }
    ?>

最佳答案

尝试这样...如果您的字段是 varchar 则意味着它可以工作。并且您需要使用 .[concodinate] 运算符声明变量。未经测试检查并让我知道。

$sql2 = mysqli_query($db, "UPDATE seller
               SET
               trade_name = '".$trade_name."',
               s_address = '".$s_address."',
               s_image = '".$filename."' 
               WHERE seller_id= '" . $_SESSION['seller_id'] . "' ");

已编辑:

尝试像这样进行更改,因为如果文件上传完成,则保存到数据库中是正确的方法...如果文件未上传到文件夹中,则在代码中运行第二个 sql2 查询。

if ($sql) {
    $id = mysqli_insert_id($db);
    $filename = $id.'.'.$extension;

    if(move_uploaded_file($_FILES['s_image']['tmp_name'], 'upload/'.$filename)) {
        $sql2 = mysqli_query($db, "UPDATE seller
               SET
               trade_name = '".$trade_name."',
               s_address = '".$s_address."',
               s_image = '".$filename."' 
               WHERE seller_id= '" . $_SESSION['seller_id'] . "' ");
        if ($sql2) {

            header('location: seller_menu.php');
        }else{
            echo "error occured : " . mysqli_error($db);
        }
    }
} else {
    echo "error occured : " . mysqli_error($db);
}

关于php - 如何使用 php 更新 sql 中的图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45540811/

相关文章:

javascript - 如何使用 Google Static Maps API 获取 map 图像的静态 URL?

c# - 如果我的应用程序中需要有 60 个图像控件,我是否必须有 60 个这样巨大的代码块?

PHP 重定向停止工作?

php date_diff 不能与 h :i A format 中的时间一起使用

php - Woocommerce 后端中的多选字段

mysql - 2 非常快速和简单的查询合并在一起时非常慢

php - 获取用斜杠分隔的 Url Codeigniter

java - Android Json HttpGet/Post HttpResponse

mysql - 从 MySQL 查询中选择最后一行

c++ - 使用opengl C++拖放图像