- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这个列表,它将根据我在 ex 数据库中的表保存所有选定复选框的 id:数据库中的我的表部分具有以下字段 id/name/qtdPecas
List<Pecas> pecasList = new ArrayList<>();
{
if (checkMonitor.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(1);
pecasList.add(p);
}
if (checkTeclado.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(2);
pecasList.add(p);
}
if (checkMouse.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(3);
pecasList.add(p);
}
if (checkVGA.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(4);
pecasList.add(p);
}
if (checkPlacaMae.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(5);
pecasList.add(p);
}
if (checkHD.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(6);
pecasList.add(p);
}
if (checkFonte.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(7);
pecasList.add(p);
}
if (checkRam.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(8);
pecasList.add(p);
}
if (checkCabos.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(9);
pecasList.add(p);
}
if (checkGravador.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(10);
pecasList.add(p);
}
if (checkBateria.isSelected()) {
Pecas p = new Pecas();
p.setIdpecas(11);
pecasList.add(p);
}
}
我有一个 list 来检查您的数据库中是否有该商品的库存
public List<Pecas> pegarPecas() {
List<Pecas> pecaslist = new ArrayList<>();
String sql = "SELECT * FROM pecas";
try {
PreparedStatement stmt = con.prepareStatement(sql);
ResultSet rs = stmt.executeQuery();
while (rs.next()) {
Pecas pecas = new Pecas();
pecas.setIdpecas(rs.getInt("id_pecas"));
pecas.setNome(rs.getString("nome"));
pecas.setQtd_Pecas(rs.getInt("qtdPecas"));
pecaslist.add(pecas);
}
stmt.close();
rs.close();
} catch (SQLException ex) {
Logger.getLogger(RequisicaoDAO.class.getName()).log(Level.SEVERE, null, ex);
return null;
}
return pecaslist;
}
我想遍历这两个列表来进行检查,选取用户选择的复选框的 id 与数据库的 id 进行比较,并选取我尝试执行此操作的可用金额:
List<Pecas> pecasList2 = new ArrayList<>();{
for (Pecas pecasVerificacao : pecasList) {
pecasVerificacao.getIdpecas();
for (Pecas pecasBanco : pecasDAO.pegarPecas()) {
if(pecasBanco.getIdpecas() == pecasVerificacao.getIdpecas()){
pecasVerificacao.setQtd_Pecas(pecasBanco.getQtd_Pecas());
pecasVerificacao.getIdpecas();
pecasList2.add(pecasVerificacao);
}
}
}
}
我不知道我是否做得最好
但是我可以获得每个选定项目所需的数据ID及数量
现在我不能做 if如果列表中每个项目的数量 > 0 调用我的方法
这一切都是为了检查数据库中的零件数量是否大于 0我没想到还有另一种方法我是java新手如果有人帮助我,我将不胜感激。
最佳答案
这不是最佳选择。
for (Pecas pecasVerificacao : pecasList) {
for (Pecas pecasBanco : pecasDAO.pegarPecas()) {
...
}
}
这将为 pecasList
中的每个元素执行一次查询。一般来说,您希望将与数据库的通信/传输的数据量保持在最低限度。多次检索所有元素是不必要的。无需太多重写的简单修复方法是仅检索一次结果并重用它们:
final List<Pecas> pecas = pecasDAO.pegarPecas();
for (Pecas pecasVerificacao : pecasList) {
for (Pecas pecasBanco : pecas) {
...
}
}
但是,这会检索到比您实际需要的更多的数据。 IN 运算符可用于仅检索您感兴趣的值。此外,您的第一个代码片段包含许多样板代码。将您的 CheckBox
存储在列表中以避免出现此问题:
private CheckBox[] checkBoxes;
确保在创建 CheckBox
es 后执行一次以下代码。
checkBoxes = new CheckBox[] {
checkMonitor,
checkTeclado,
checkMouse,
checkVGA,
checkPlacaMae,
checkHD,
checkFonte,
checkRam,
checkCabos,
checkGravador,
checkBateria
};
(如果不能保证索引范围为1, ..., n,您可能需要使用不同的数据结构来存储数据。
这样您就可以重写填充 pecasList
的代码,如下所示(我只是在此处存储 id):
List<Integer> pecasList = new ArrayList<>();
for (int i = 0; i < checkBoxes.length; i++) {
if (checkBoxes[i].isSelected()) {
pecasList.add(i+1);
}
}
public List<Pecas> pegarPecasById(List<Integer> ids) {
if (ids.isEmpty()) {
return new ArrayList<>(0);
} else {
String sql = ids.stream().map(Object::toString).collect(Collectors.joining(",", "SELECT * FROM pecas WHERE id_pecas IN (", ")"));
try {
PreparedStatement stmt = con.prepareStatement(sql);
ResultSet rs = stmt.executeQuery();
while (rs.next()) {
Pecas pecas = new Pecas();
pecas.setIdpecas(rs.getInt("id_pecas"));
pecas.setNome(rs.getString("nome"));
pecas.setQtd_Pecas(rs.getInt("qtdPecas"));
pecaslist.add(pecas);
}
stmt.close();
rs.close();
} catch (SQLException ex) {
Logger.getLogger(RequisicaoDAO.class.getName()).log(Level.SEVERE, null, ex);
return null;
}
return pecaslist;
}
}
这样您就可以获得复选框的唯一结果。这应该使嵌套循环变得不必要。
关于java - 如何浏览 2 个列表并进行检查,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56910131/
我遇到一个问题,即我的抓取工具正在跳过没有浏览引荐来源网址的浏览页面。我正在尝试解析 URL 中包含/browse/的所有页面,无论引用者如何。 以下是我的代码(根据 paul t 更新): from
我有4个屏幕。 X,A,B,C。导航模式应如下所示 这是代码 X 屏幕 class X extends StatelessWidget { @override Widget build(Bui
我想用 java 编写一个简单的网络浏览器,这是我的代码! import javax.swing.*; import java.io.*; import java.awt.*; import java
这个问题在这里已经有了答案: A home button in iOS 5, xcode 4.2, Story board (2 个回答) 8年前关闭。 来自 FirstView到SecondView
我使用 C#/ASP.Net 在 IIS7 中创建虚拟目录,以便外部人员可以浏览各种文档。 一切看起来都不错,除了浏览是一种沉闷的文本格式。当他们浏览到文件夹时,我如何创建更多的“Windows 资源
我想我在 Chrome 或 Internet Explorer 中见过 Gmail 这样做,但我从未在 Firefox 中见过它。我想我还是会问一下。是否可以在不需要的情况下进行文件上传?我看到你可以
我是 Java 的新手,作为第一次阅读,我阅读了几本有关 Java 语言的书籍。 我有几个关于 Java 文档的问题。如何“导航”它们?是否可以仅使用 Javadoc 来学习新概念? 这是一个示例 -
我有一个解析网络,现在我想浏览标签,或显示图表。我怎样才能得到图表?或者在树中导航。显示第一步然后其他等。并了解这棵树是如何 build 的。 import urllib from lxml impo
考虑以下情况: 杀戮戒指中的 N 项。需要拉取的项目是项目#k 数值论证解决方案不会真正起作用,因为计算或跟踪杀死环中事物的位置很烦人。 最佳答案 实际问题是什么?按 C-y 然后按 M-y k 次有
这是我之前的 question 的后续。 我试图从 here 了解 Haskell 中的列表拆分示例: foldr (\a ~(x,y) -> (a:y,x)) ([],[]) 我可以阅读 Haske
是否有任何 vim 工具通过 Latex 文档结构提供有效的导航。拥有像 NERDTree 面板这样的东西来表示 latex 文档的部分/子部分结构会非常有用。 最佳答案 扩展 mnosefishs
您好,我的应用程序中有一个模态视图 Controller ,当按下某个按钮时,该 Controller 会消失,并且其中带有 UITableView 的 View 会使用导航 Controller 滑
Glances v2.11.1 with psutil v5.4.3 /usr/lib/python3.6/site-packages/psutil/_pslinux.py:1152: Runtime
我正在使用 Eclipse,我希望我可以通过按 STRG 在以驼峰式书写的单词之间跳转。现在我正在使用 Sublime,我找不到这样做的快捷方式,也找不到实现它的插件。 下面的例子说明了我的问题 aF
我的主程序提示用户浏览文件以便使用 ffmpeg 进行转换。这是文件浏览的格式: 1. Select audio file for conversion ( mp3, wma):
我正在尝试浏览 SVN 存储库,而不必检查它: 是否可以在本地(Unix 上)执行此操作? 这可以通过 ssh 访问实现吗? 最佳答案 svn ls 有效。例如 svn ls http://my.sv
我有一个网站,其中列出了数据库中的企业列表。在每个页面上,您可以执行不同的操作,例如将其转发给 friend 、打印页面等。我的问题是我可以使用谷歌分析来跟踪每个列表的展示次数和浏览次数吗?因此,如果
在 Dart 我有一个嵌套的元素列表 void main() { var diction = {'1':'Alpha','2':'Beta','3':{'x':'Football','y':'
当我们的用户单击网页上的浏览按钮来上传任何文件时,我想更改窗口位置。我会给你一个场景 - 我的 html 表单上有一个浏览按钮,当用户单击一个弹出窗口时,该位置默认为“我的文档”。 实际上我想在单击“
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
我是一名优秀的程序员,十分优秀!