- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
难以将数组数据输入数据库表
我想知道是否有人可以指出以下脚本有什么问题。我在将数组数据输入数据库表时遇到困难。下面给出了完整的代码,以及应输入到数据库表中的最终数组的结果,以 print_r()
格式打印出来。
就收集 6 个数据数组的内容和创建 MySQL 数据库表而言,一切似乎都运行正常。困难在于代码的最后一部分,将数据输入到数据库表中。
脚本的底部包含 5 个不同版本的 MySQL 命令,这些命令是由应已将数据输入数据库表的其他贡献者和站点用户提供的。我分别尝试了每个版本,但所有 5 个版本都无法工作。版本标签旁边的注释说明了失败的模式。
任何帮助将不胜感激。
<?php
// Data Arrays (6)
$current_topic_array = array();
$post_date_array = array();
$phone_array = array();
$item_title_original_array = array();
$item_title_array = array();
$item_link_original_array = array();
// Enter Data into the Data Arrays.
// This can be done either by local loop as shown here, or gathered from an earlier part of the routine
for($c = 0; $c < 3; $c++) { // eventually the maximum value shown here, 3, will be a $variable
$current_topic_array[] = 'a'.$c; // text string - Topic Section
$post_date_array[] = 'b'.$c; // text string - Article Post Date as text string i.e. 03-30-2012
$phone_array[] = 'c'.$c; // text string - Author's Contact Phone number as text string i.e. 888-555-1212
$item_title_original_array[] = 'd'.$c; // text string - Original Article Title
$item_title_array[] = 'e'.$c; // text string - Modified Article Title (shortened)
$item_link_original_array[] = 'f'.$c; // text string - Author's website URL i.e. http://www...
}
// MySQL Database Connection - Authentication: user, password
$TableName = 'User_Data';
$dbh = mysql_connect ("localhost", "user", "password")
or die ('Cannot connect to the database because: ' . mysql_error());
mysql_select_db ("database");
// Creates a Database Table only if the Table does not already exist
if(mysql_num_rows(mysql_query("SHOW TABLES LIKE '".$TableName."'")) != 1) {
mysql_query("CREATE TABLE $TableName(
id INT NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id),
Topic varchar(300) NOT NULL default '',
Post_Date varchar(100) NOT NULL default '',
Phone_Number varchar(100) NOT NULL default '',
Original_Item_Title varchar(2000) NOT NULL default '',
Modified_Item_Title varchar(2000) NOT NULL default '',
Original_Item_Link varchar(2000) NOT NULL default '') ") or die(mysql_error()
);
}
// Combine all 6 Data Array into one array
$queries = array();
for($i = 0; $i < count($current_topic_array); $i++) {
$queries[] = '(
'.$current_topic_array[$i].',
'.$post_date_array[$i].',
'.$phone_array[$i].',
'.$item_title_original_array[$i].',
'.$item_title_array[$i].',
'.$item_link_original_array[$i].'
)';
// Check - $queries array item &i
echo '<span style="color: #008000;">'.$queries[$i].'</span>';
}
// Check - Final $queries array content
echo '<hr>Final $queries array content =';
echo '<pre>';
print_r($queries);
echo '</pre>';
echo '<hr>';
// Enter the $queries Data into the MySQL Database Table
// Version 1 - Failed: Column count doesn't match value count at row 1
// mysql_query("insert into $TableName (Topic, Post_Date, Phone_Number, Original_Item_Title, Modified_Item_Title, Original_Item_Link)
// values (". implode(',', $queries) . ")") or die(mysql_error());
// Version 2 - Failed: Column count doesn't match value count at row 1
// mysql_query("insert into $TableName (Topic, Post_Date, Phone_Number, Original_Item_Title, Modified_Item_Title, Original_Item_Link)
// values ('". implode("','", $queries) . "')") or die(mysql_error());
// Version 3 - Failed - No Error message and No Data imported into Table
// $query = mysql_query("insert into $TableName (Topic, Post_Date, Phone_Number, Original_Item_Title, Modified_Item_Title, Original_Item_Link)
// values ('. implode(',', $queries)') or die(mysql_error()");
// Version 4 - Failed - No Error message and No Data imported into Table
// $query = "insert into User_Data(Topic, Post_Date, Phone_Number, Original_Item_Title, Modified_Item_Title, Original_Item_Link)
// values " . implode(", ", $queries);
// Version 5 - Failed - No Error message and No Data imported into Table
$query = "insert into (Topic, Post_Date, Phone_Number, Original_Item_Title, Modified_Item_Title, Original_Item_Link)
values " . implode(", ", $queries);
?>
$queries[$i]
项:
( a0, b0, c0, d0, e0, f0 )( a1, b1, c1, d1, e1, f1 )( a2, b2, c2, d2, e2, f2 )
最终$queries
数组内容:
Array
(
[0] => (
a0,
b0,
c0,
d0,
e0,
f0
)
[1] => (
a1,
b1,
c1,
d1,
e1,
f1
)
[2] => (
a2,
b2,
c2,
d2,
e2,
f2
)
)
最佳答案
根据 MySql reference :
INSERT INTO tbl_name (a,b,c) VALUES(1,2,3),(4,5,6),(7,8,9);
这是一次插入多行的方法。请注意值之间的“,”。尽管使用 for 循环逐行插入数据并从查询数组中取出第 i 行会更容易、更安全。
另外,我想指出的是,目前代码很容易受到 SQL 注入(inject)攻击,因为它操作字符串并且没有 sql 检查。
关于mysql - 将数组数据输入数据库表时遇到困难,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10005562/
初学者 android 问题。好的,我已经成功写入文件。例如。 //获取文件名 String filename = getResources().getString(R.string.filename
我已经将相同的图像保存到/data/data/mypackage/img/中,现在我想显示这个全屏,我曾尝试使用 ACTION_VIEW 来显示 android 标准程序,但它不是从/data/dat
我正在使用Xcode 9,Swift 4。 我正在尝试使用以下代码从URL在ImageView中显示图像: func getImageFromUrl(sourceUrl: String) -> UII
我的 Ubuntu 安装 genymotion 有问题。主要是我无法调试我的数据库,因为通过 eclipse 中的 DBMS 和 shell 中的 adb 我无法查看/data/文件夹的内容。没有显示
我正在尝试用 PHP 发布一些 JSON 数据。但是出了点问题。 这是我的 html -- {% for x in sets %}
我观察到两种方法的结果不同。为什么是这样?我知道 lm 上发生了什么,但无法弄清楚 tslm 上发生了什么。 > library(forecast) > set.seed(2) > tts lm(t
我不确定为什么会这样!我有一个由 spring data elasticsearch 和 spring data jpa 使用的类,但是当我尝试运行我的应用程序时出现错误。 Error creatin
在 this vega 图表,如果我下载并转换 flare-dependencies.json使用以下 jq 到 csv命令, jq -r '(map(keys) | add | unique) as
我正在提交一个项目,我必须在其中创建一个带有表的 mysql 数据库。一切都在我这边进行,所以我只想检查如何将我所有的压缩文件发送给使用不同计算机的人。基本上,我如何为另一台计算机创建我的数据库文件,
我有一个应用程序可以将文本文件写入内部存储。我想仔细看看我的电脑。 我运行了 Toast.makeText 来显示路径,它说:/数据/数据/我的包 但是当我转到 Android Studio 的 An
我喜欢使用 Genymotion 模拟器以如此出色的速度加载 Android。它有非常好的速度,但仍然有一些不稳定的性能。 如何从 Eclipse 中的文件资源管理器访问 Genymotion 模拟器
我需要更改 Silverlight 中文本框的格式。数据通过 MVVM 绑定(bind)。 例如,有一个 int 属性,我将 1 添加到 setter 中的值并调用 OnPropertyChanged
我想向 Youtube Data API 提出请求,但我不需要访问任何用户信息。我只想浏览公共(public)视频并根据搜索词显示视频。 我可以在未经授权的情况下这样做吗? 最佳答案 YouTube
我已经设置了一个 Twilio 应用程序,我想向人们发送更新,但我不想回复单个文本。我只是想让他们在有问题时打电话。我一切正常,但我想在发送文本时显示传入文本,以确保我不会错过任何问题。我正在使用 p
我有一个带有表单的网站(目前它是纯 HTML,但我们正在切换到 JQuery)。流程是这样的: 接受用户的输入 --- 5 个整数 通过 REST 调用网络服务 在服务器端运行一些计算...并生成一个
假设我们有一个名为 configuration.js 的文件,当我们查看内部时,我们会看到: 'use strict'; var profile = { "project": "%Projec
这部分是对 Previous Question 的扩展我的: 我现在可以从我的 CI Controller 成功返回 JSON 数据,它返回: {"results":[{"id":"1","Sourc
有什么有效的方法可以删除 ios 中 CBL 的所有文档存储?我对此有疑问,或者,如果有人知道如何从本质上使该应用程序像刚刚安装一样,那也会非常有帮助。我们正在努力确保我们的注销实际上将应用程序设置为
我有一个 Rails 应用程序,它与其他 Rails 应用程序通信以进行数据插入。我使用 jQuery $.post 方法进行数据插入。对于插入,我的其他 Rails 应用程序显示 200 OK。但在
我正在为服务于发布请求的 API 调用运行单元测试。我正在传递请求正文,并且必须将响应作为帐户数据返回。但我只收到断言错误 注意:数据是从 Azure 中获取的 spec.js const accou
我是一名优秀的程序员,十分优秀!