gpt4 book ai didi

php - 如何将字符串或值附加到 mysql php 中的现有列

转载 作者:行者123 更新时间:2023-11-30 01:22:09 25 4
gpt4 key购买 nike

<?php
if(empty($_POST['keyword_submit']) === false && empty($errors) === true)
{
$data_keyword = array(
'keywords'=> $_POST['keywords']
);
data_keyword($data_keyword);
header('Location: keyword.php');
exit();
}
?>
<form method="post" id="mainformkey">
<table width="100%">
<tr>
<td style="padding: 5px;">
<table id="keyword_table" width="100%" border="1" >
<tr>
<th width="60%">
Keywords
</th>
<th width="10%">
Keyword ID
</th>
<th width="9%">
Words
</th>
</tr>
<?php
$keyword_sql1 = mysql_query("SELECT * FROM keyword");
while($row_keyword_sql1 = mysql_fetch_array($keyword_sql1)){
$id1 = $row_keyword_sql1[id];
}
if(isset($_POST[keyword_submit_add])){
$values_keyword = $_POST['keywords_extra'];
$ds = mysql_query("UPDATE keyword SET keywords = CONCAT(keywords,$values_keyword) WHERE id = '$id1'");
}
$keyword_sql = mysql_query("SELECT * FROM keyword WHERE user_id='$session_user_id'");
while($row_keyword_sql = mysql_fetch_array($keyword_sql)){
$id = $row_keyword_sql[id];
$get_keyword = $row_keyword_sql[keywords];
?>
<tr>
<td>
<?php echo $get_keyword;
?>
</td>
<td align="center">
<?php echo '@key-0'.$id;?>
</td>
<td align="center">
<form id="addnew" method="post">
<input type="text" name="keywords_extra">
<input type="submit" name="keyword_submit_add" value="Add keyword">
</form>
</td>
</tr>
<?php
}
?>
</table>
</td>
</tr>
<tr>
<td style="background: #EDEDED; padding: 5px;">
<input type="text" name="keywords">
<input type="submit" name="keyword_submit" value="Main Keyword">
</td>
</tr>
</table>
</form>
<?php
function data_keyword($data_keyword)
{
array_walk($data_keyword, 'array_sanitize');
$fields = '`' . implode('`, `', array_keys($data_keyword)) . '`';
$data = '\'' . implode('\', \'', $data_keyword) . '\'';
mysql_query("INSERT INTO `keyword` ($fields) VALUES ($data)");
}
?>

这里有两个提交按钮 1.第一个提交按钮:用户可以输入一个关键字并提交(名称:主关键字)。 2. 第二个提交按钮:其次,他们可以将关键字输入到特定行,该行可以附加逗号分隔。

我已经尝试在 mysql 中使用 CONCAT,但只有逗号被附加,并且在所有行中也是如此,但我需要根据 id 在特定行中。

最佳答案

使用concat_ws而不是 concat,以便您可以传入您选择的分隔符。

尝试:

$ds = mysql_query("UPDATE keyword SET keywords = CONCAT_WS(' ', keywords, $values_keyword) WHERE id = '$id1'");

您提到的另一个问题与您从 $row_keyword_sql1 数组访问 id 相关。请注意,如果数组索引不是变量,则它们需要在引号内,在这种情况下,它绝对不是变量,即 $id。另外,我认为您希望对 $row_keyword_sql1 中的每个 id 执行此查询,而不仅仅是最后一个。

尝试:

while($row_keyword_sql1 = mysql_fetch_array($keyword_sql1)){
$id1 = $row_keyword_sql1['id'];

if(isset($_POST['keyword_submit_add'])){ // Updated to use index in quotes.
$values_keyword = $_POST['keywords_extra'];
$ds = mysql_query("UPDATE keyword SET keywords = CONCAT_WS(' ', keywords,$values_keyword) WHERE id = '$id1'");
}
}

更新:

替换以下行:

$id1 = $row_keyword_sql1[id];
...
if(isset($_POST[keyword_submit_add])){
...
$get_keyword = $row_keyword_sql[keywords];

与:

$id1 = $row_keyword_sql1['id'];
...
if(isset($_POST['keyword_submit_add'])){
...
$get_keyword = $row_keyword_sql['keywords'];

您可能已经意识到 mysql_ 函数已被弃用,最好切换到 mysqlipdo早期的。另请记住,将posted值直接发送到数据库很容易受到SQL注入(inject)的攻击,您至少应该对它们调用mysql_real_escape_string,例如$keyword = mysql_real_escape_string($_POST['keywords'])

关于php - 如何将字符串或值附加到 mysql php 中的现有列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18417282/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com