- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 html 表单,允许用户将设备添加到数据库中。一个用户可以添加多件设备,有时设备之间唯一不同的字段是库存编号 和MAC 地址。
例如,他们可能想要添加 10 台具有相同硬件的戴尔 PC。他们可以动态添加Inventory Number 和MAC Address 字段,而不是让他们提交 10 个表单。
表单输入看起来像这样;
<form method="POST" action="">
<input type="text" name="make">
<input type="text" name="model">
<input type="text" name="inv[]">
<input type="text" name="mac[]">
<input type="submit" name="submit">
</form>
我可以提交表单,print_r($_POST)
的输出是;
Array
(
[make] => Dell
[model] => Optiplex
[inv] => Array
(
[0] => 1544778
[1] => 3344558
[2] => 1644758
[3] => 9844558
)
[mac] => Array
(
[0] => 8877445
[1] => 3311554
[2] => 7788445
[3] => 3214857
)
)
在上面的示例中,我需要在 mysql 数据库中创建四个 个单独的记录。
考虑到我需要遍历这些值并单独插入它们,我有以下 PHP;
$arr_inv = $_POST['inv'];
$arr_mac = $_POST['mac'];
for ($i = 0; $i < count($arr_inv); $i++) {
$sql = "INSERT INTO table (make, model, inv, mac)
VALUES ('" . $make . "', '" . $model . "', '" . $arr_inv[$i] . "','" . $arr_mac[$i];
$stmt = DB::exec($sql);
}
虽然这确实有效,并且将 4 条单独的记录插入到数据库中,但这是最好的方法吗/我怎样才能让它更有效率?
请忽略代码中的任何安全漏洞,仍在努力。任何建议表示赞赏。
最佳答案
基本上,您可以将所有行合并到一个INSERT
查询中 - 确切的语法可能取决于您使用的数据库,但通常它应该如下所示:
INSERT INTO table (make, model, inv, mac)
VALUES
(make1, model1, inv1, mac1),
(make2, model2, inv2, mac2)
如果您必须执行大量查询 - 这可以显着提高性能。
UPD. 正如 @Vatev 所建议的那样,我删除了代码示例,因为它不包含任何数据转义和验证,因此它可能会导致某些项目中的潜在漏洞,所以我只留下共同的想法描述。
关于php - 将输入数组形成到 MySQL DB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51723959/
我正在阅读 deduction guides在 C++17 中。假设我们有以下示例: template struct Custom { }; template struct Person {
我在我的 xamarin 表单项目中使用选项卡式页面。我正在尝试在 Android 的 MyTabsRenderer 类中使用 OnTabReselected 事件。但不会调用 OnTabSelect
我对 NSPredicate 有疑问。想不出一种写法,也找不到类似的东西。我有这个谓词: [NSPredicate predicateWithFormat:@"followedBy.username
我的模态中有一个小表单,如下所示: Name
我正在尝试制作用于表单验证的 jquery 插件(用于学习)。在此表单中,我无法获取类名称为“required”的所有表单字段。代码如下: (function( $ ) { $.fn.kValidat
在我的 Android 应用中,我从 Google Place API 获取附近餐馆的列表。 但不幸的是,这个列表没有给出餐厅的菜单。 我有 T_RESTAURANT 和 T_MENU 表。 假设我在
我正在尝试使用 angular.js 和 devise 设置登录。 这是我的表单 html: Email Password
谁能告诉我如何让生成的文档从表单中提取数据并将其作为标题?我已经查看了 Google Script 文档,但到目前为止我还没有找到任何可以回答我或向我展示类似示例的内容。到目前为止,我在这里找到了相关
当我有这样的表格时: “.”是什么意思?在行动中代表什么? 最佳答案 action 属性告诉表单将表单数据发布到哪里。 . 代表当前目录,所以我会说这是发布到当前目录中的默认文档。 相对路径有几
Mockito 似乎是一个非常漂亮的 Java stub /模拟框架。唯一的问题是我找不到任何关于使用他们的 API 的最佳方式的具体文档。测试中常用的方法包括: doXXX(???) : Stubb
我有 2 份表格。我从一种形式创建并展示了另一种形式。效果很好。但是,当我尝试从创建该表单的表单中关闭或处理该表单时,出现以下异常: Exception : Value Dispose() can
将我的应用程序上传到 TestFlight 时出现以下错误。 但是,我没有看到 missing 的任何位置Xamarin Assets 菜单中的图标。 (76x76、167x167 和 152x152
我的models.py文件看起来像这样 from django.db import models from django.template.defaultfilters import slugify
问题 学习 Xamarin 大学类(class) XAM120 .在将我的 IDial 实现添加到我的 UWP 项目时遇到障碍。出于某种原因,我的项目没有在我的系统上使用 PhoneCallManag
我在应用程序的列表页面上使用了 FloatingActionButton,我还想添加一个 searchBar。但我无法向他们展示该页面。我的代码和屏幕截图已关闭。如何显示搜索栏? FAB Github
实体产品和类别之间存在经典的多对多关系,其中一个产品可能包含在多个类别中。我们想在 UI 中使用带有 UITableViewController 或 UICollectionView 的 NSFetc
html 代码: js代码: function show(){ $.ajax({
我有一个用户列表。现在任何一个名字很长的用户都在搞乱排列/排列。 我认为通过为名称设置大小可以达到目的: .invitee .name{ height: 50px; width: 115px;
我正在使用 Flask 框架和 WTforms 库,我在更改选择字段中每个选项的颜色时遇到了问题,因为它总是显示为黑色而不是红色 我在模板中有下一个表单
Dugen Chen 写了一篇有用的文章,介绍如何将 HTML5 验证中的“required”属性添加到 Django 表单字段。 http://duganchen.ca/elegantly-addi
我是一名优秀的程序员,十分优秀!