为了账号安全,请及时绑定邮箱和手机立即绑定

使用 PDO (PHP) 在 mySQL 数据库中插入数字数据

使用 PDO (PHP) 在 mySQL 数据库中插入数字数据

PHP
一只甜甜圈 2023-12-15 15:32:11
我正在尝试使用 PHP 数据对象(PDO)在 MySQL 数据库中插入字符串(:make 和:model)和数字(:year 和:mileage)数据。问题是代码没有在数据库中插入数字数据(我猜原因是代码自动将 :year 和 :mileage 数据类型从 int 更改为 str。“year”和DB 表中的“里程”列是 INT 类型。)如何更改代码以插入 :year 和 :mileage 作为 INT 数据?//PDO<?php$pdo = new PDO('mysql:host=localhost;port=8888;dbname=xxxx',    'xxx', 'xxx');$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); //SQL  $sql = "INSERT INTO autos (make, model, year, mileage)                  VALUES (:make, :model, :year, :mileage)";        $stmt = $pdo->prepare($sql);        $stmt->execute(array(            ':make' => $_POST['make'],            ':model' => $_POST['model'],            ':year' => $_POST['year'],            ':mileage' => $_POST['mileage']));        $_SESSION['success'] = 'Record Added';        header( 'Location: index.php' ) ;        return;?><form method="post"><p>Make:<input type="text" name="make"></p><p>Model:<input type="text" name="model"></p><p>Year:<input type="number" name="year"></p><p>Mileage:<input type="number" name="mileage"></p><p><input type="submit" value="Add New"/><!--SQL schema--!>CREATE TABLE autos (  autos_id INTEGER NOT NULL KEY AUTO_INCREMENT,  make VARCHAR(255),  model VARCHAR(255),  year INTEGER,  mileage INTEGER) ENGINE=InnoDB DEFAULT CHARSET=utf8;
查看完整描述

1 回答

?
Qyouu

TA贡献1786条经验 获得超11个赞

这里的问题是 PHP POST 数据是字符串,因此您需要在插入之前对其进行转换。


<--PDO code-->

<?php

$pdo = new PDO('mysql:host=localhost;port=8888;dbname=xxxx', 

   'xxx', 'xxx');

$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);


 //SQL 

 $sql = "INSERT INTO cars (make, model, year, mileage)

                  VALUES (:make, :model, :year, :mileage)";

        $stmt = $pdo->prepare($sql);

        $stmt->execute(array(

            ':make' => $_POST['make'],

            ':model' => $_POST['model'],

            ':year' => intval($_POST['year']),

            ':mileage' => intval($_POST['mileage'])));

        $_SESSION['success'] = 'Record Added';

        header( 'Location: index.php' ) ;

        return;

?>


<form method="post">

<p>Make:

<input type="text" name="make"></p>

<p>Model:

<input type="text" name="model"></p>

<p>Year:

<input type="number" name="year"></p>

<p>Mileage:

<input type="number" name="mileage"></p>

<p><input type="submit" value="Add New"/>


查看完整回答
反对 回复 2023-12-15
  • 1 回答
  • 0 关注
  • 51 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信