【问题标题】:Textarea each line is a new value in the dbTextarea 每一行都是数据库中的一个新值
【发布时间】:2015-05-21 20:37:30
【问题描述】:

我想知道如何使用 textarea 使每一行在我的数据库中成为一个新值。

例如,我会将其放在文本区域中:

1
2
3

然后每个值 (1,2,3) 将作为不同的值出现。 我该如何继续这样做?

这是我目前正在做的事情:

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);

// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

$sql = "INSERT INTO MyGuests (firstname, lastname, email) VALUES ('John', 'Doe', 'john@example.com')";

if ($conn->query($sql) === TRUE) {
    echo "New record created successfully";
} else {
    echo "Error: " . $sql . "<br>" . $conn->error;
}

$conn->close();
?>

【问题讨论】:

  • 根据分隔符分割文本。有很多方法可以做到这一点。请提供一些您的测试代码。
  • 嗨 Twisty,我正在使用这个。 &lt;?php $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "myDB"; // Create connection $conn = new mysqli($servername, $username, $password, $dbname); // Check connection if ($conn-&gt;connect_error) { die("Connection failed: " . $conn-&gt;connect_error); } $sql = "INSERT INTO MyGuests (firstname, lastname, email) VALUES ('John', 'Doe', 'john@example.com')"; if ($conn-&gt;query($sql) === TRUE) { echo "New record created successfully"; } else { echo "Error: " . $sql . "&lt;br&gt;" . $conn-&gt;error; } $conn-&gt;close(); ?&gt;

标签: php database insert textarea


【解决方案1】:

假设你的文字是:

1\r\n
2\r\n
3\r\n

您可以根据回车符 (\r)、换行符 (\n) 分隔标记行尾的字符(在 Windows 中)。或者只是 New Line,因为 Linux 将只使用 New Line 作为 EOL。

http://php.net/manual/en/function.explode.php

假设您从表单中获取以下数据:

"John\r\nDoe\r\njohn@example.com\r\n"

我们使用explode() 将其分块成一个数组:

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);

// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

$parts = explode("\n", $_POST['myTextBox']);

$sql = $conn->prepare("INSERT INTO MyGuests (firstname, lastname, email) VALUES (?, ?, ?)");
$sql->bind_param($sql, 'sss', $parts[0], $parts[1], $parts[2]);

if ($sql->execute() === TRUE) {
    echo "New record created successfully";
} else {
    echo "Error: . $conn->error;
}

$conn->close();
?>

这是相当危险的,因为您几乎无法控制表单输入。我会将它们分成 3 个独特的文本框。我还会在提交表单之前和之后在 PHP 提取数据时验证输入。

【讨论】:

    猜你喜欢
    • 2017-06-15
    • 1970-01-01
    • 2017-01-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-08-05
    • 2016-04-23
    • 1970-01-01
    相关资源
    最近更新 更多