将php表单信息更新到sql server数据库时出错

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了将php表单信息更新到sql server数据库时出错相关的知识,希望对你有一定的参考价值。

我在php中创建了表单,并希望更新sql server数据库中的数据。

以下是我的ad.php文件。

<html>
<title>FORM</title>
<body><br><br>
<form action ="db_connection.php" method="post">
Activity:<input type="text" name="name"><br><br>
Units: <input id="number"><br><br>

<input type="submit" value="submit">
</form>

插入上述表格的数据应在数据库的“广告”表中更新。

以下是我的db_connection.php文件:

<?php

class DB{
protected static $db;
const SERVER = "";
const SCHEMA = "";
const USER = "";
const PASS = "";
/*
 * Sets up the database connection
 * @return the database instance
 */
public static function databaseConnection(){
    if(!self::$db){
        try {

            $databse = "sqlsrv:server=" . self::SERVER . ";Database=" . self::SCHEMA;
            self::$db = new PDO($databse, DB::USER, DB::PASS);  
            self::$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );  
        } catch(PDOException $e){
            die("Error " . $e->getMessage());
        }   
    }
    return self::$db;
}

}


class ad{

  public function dbAdmin(vat $Activity, int $Units): bool {
    $conn = databaseConnection::getConnection();
    $conn->beginTransaction();
    $sql = "INSERT INTO ad('Activity', 'Units') VALUES (:Activity, :Units)";
    $stmt = $conn->prepare($sql);
    $stmt->bindParam(':Units', $Units);
    $stmt->bindParam(':Activity', $Activity);
    if ($stmt->execute()) {
        $conn->commit();
        return true;
    } else {
        $conn->rollback();
        return false;
    }
}
}

我在提交表单后得到一个空白页面,并且数据库没有使用提交的新数据进行更新。你可以检查代码并帮我纠正。

答案

我不得不使用Docker重现这个。正在使用容器“microsoft / mssql-server-linux”。

I am using this extension **pdo_sqlsrv** and this driver https://breeto.id.au/2017/05/docker-alpine-linux-php-sql-server/

的index.html

<!DOCTYPE>
<html>
<head>
    <title>FORM</title>
</head>
<body>
<br/>
<br/>
<form action="index.php" method="post">
    <label for="activity">Activity: </label>
    <input id="activity" type="text" name="activity">
    <br/>
    <br/>
    <label for="number">Units: </label>
    <input id="number" type="number" name="units">
    <br/>
    <br/>
    <input type="submit" value="submit">
</form>
</body>
</html>

的index.php

<?php
declare(strict_types=1);

require_once __DIR__ . '/Db.php';
require_once __DIR__ . '/Ad.php';

error_reporting(E_ALL);
ini_set('display_errors', '1');
ini_set('display_startup_errors', '1');
ini_set('log_errors', '1');

$post = ['activity', 'units'];
if (!isset($_POST['activity'], $_POST['units'])) {
  header('Invalid form', TRUE, 422);
  exit;
}

$activity = filter_input(INPUT_POST, 'activity', FILTER_SANITIZE_SPECIAL_CHARS);
$units    = (int) filter_input(INPUT_POST, 'units', FILTER_SANITIZE_NUMBER_INT);
if (!is_int($units)) {
  header('A number must be given', TRUE, 422);
  exit;
}

$adTable = new Ad();
$adTable->dbAdmin($activity, $units);

echo '<h1>Done</h1>';
echo "<p>Activity: {$activity}</p>";
echo "<p>Units: {$units}</p>";

db.php中

<?php
declare(strict_types=1);


/**
 * Class Db
 */
class Db {

  protected static $db;

  public const SERVER = 'mssql';

  public const SCHEMA = 'stackoverflow';

  public const USER = 'sa';

  public const PASS = '';

  /**
   * Sets up the database connection
   *
   * @return PDO
   */
  public static function databaseConnection(): PDO {
    if (!self::$db) {
      try {
        $dsn      = 'odbc:Driver={FreeTDS};Server=' . self::SERVER . ';Database=' . self::SCHEMA . ';Port=1433';
        self::$db = new PDO($dsn, DB::USER, DB::PASS);
        self::$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
      } catch (PDOException $e) {
        die('Error ' . $e->getMessage());
      }
    }
    return self::$db;
  }
}

Ad.php

<?php
declare(strict_types=1);


/**
 * Class Ad
 */
class Ad {

  public function dbAdmin(string $activity, int $units): bool {
    $conn = Db::databaseConnection();
    $conn->beginTransaction();
    $sql  = /** @lang TSQL */
      'INSERT INTO stackoverflow.dbo.ad (Activity, Units) VALUES (:Activity, :Units)';
    $stmt = $conn->prepare($sql);
    $stmt->bindParam(':Activity', $activity, PDO::PARAM_STR);
    $stmt->bindParam(':Units', $units, PDO::PARAM_INT);
    if ($stmt->execute()) {
      $conn->commit();
      return TRUE;
    }
    $conn->rollBack();
    return FALSE;
  }
}

SQL Server(Microsoft)表

CREATE TABLE ad
(
  id       INT IDENTITY
    PRIMARY KEY,
  Activity VARCHAR(255),
  Units    INT
)
GO
另一答案

你必须将name属性也放在单位字段中..表格通过其字段名称提交....

更正: -

<html>
<title>FORM</title>
<body><br><br>
<form action ="db_connection.php" method="post">
Activity:<input type="text" name="name"><br><br>
Units: <input id="number" name="number><br><br>

<input type="submit" value="submit">
</form>
另一答案

我不确定你到底想要做什么,因为它是完全不完整的代码。

  1. 你的$_POST阵列在哪里?你如何以及在哪里检索POST请求数据?
  2. dbAdmin是执行数据插入的方法,但是如何调用此方法?你在哪里实例化类并调用这个方法?
  3. 什么是vat数据类型在这里声明dbAdmin(vat $Activity, int $Units)
  4. 您在html表单中缺少nameUnits属性。

以上是关于将php表单信息更新到sql server数据库时出错的主要内容,如果未能解决你的问题,请参考以下文章

php表单未将日期发送到数据库SQL

表单信息未更新到我的数据库

从 PHP/HTML 表单更新 SQL

更新 SQL Server 数据库时如何更新 MS Access 表单?

php表单没有插入到sql数据库

PHP / SQL在表单完成时存储当前登录用户的名称