- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 jsoup 从网站提取一些数据并将其存储到数组列表中。现在我想将数据存储到mysql数据库中。这是我的代码,但我得到了这个 java.sql.SQLException: No value specified forparameter 2
这是我从网站获取数据的类(class)。
public class Twrapper {
ArrayList<MobilePhone> skrouztPhones = new ArrayList<>();
protected ArrayList<MobilePhone> getPhoneNames() throws IOException{
for (int j=1; j<=1;j++){
Document mobilePhones = Jsoup.connect("http://www.skroutz.gr/c/40/kinhta-thlefwna.html?order_dir=asc&page=" + j).userAgent("Mozilla").get();
Elements phoneName = mobilePhones.select("div[class=details]");
for(int i = 1; i<phoneName.size();i++){
MobilePhone names = new MobilePhone();
names.setName(phoneName.get(i).text());
skrouztPhones.add(names);
}
}
return skrouztPhones;
}
protected ArrayList<MobilePhone> getPhonesUrls() throws IOException{
for(int j =1; j<=1;j++){
Document mobilePhone = Jsoup.connect("http://www.skroutz.gr/c/40/kinhta-thlefwna.html?order_dir=asc&page=" + j).userAgent("Mozilla").get();
Elements phoneUrls = mobilePhone.select("div[class=details] a ");
for(int i =0; i<phoneUrls.size(); i++){
MobilePhone urls = new MobilePhone();
urls.setUrl(phoneUrls.get(i).absUrl("href"));
skrouztPhones.add(urls);
}
}
return skrouztPhones;
}
}
这是我将数据存储到数据库的方法。
public static void main(String[] args) throws IOException, SQLException{
Twrapper wrapper = new Twrapper();
try
{
// create a mysql database connection
String myDriver = "org.gjt.mm.mysql.Driver";
String myUrl = "jdbc:mysql://83.212.124.175:3306/zadmin_java?useUnicode=yes&characterEncoding=UTF-8";
Class.forName(myDriver);
System.out.println("Connecting to a selected database...");
Connection conn = DriverManager.getConnection(myUrl, "usr", "pass");
System.out.println("Connected database successfully...");
// the mysql insert statement
String query = " INSERT INTO skrouzt(url,name)"
+ " values (?, ?)";
PreparedStatement updateSkrouztPs = conn.prepareStatement(query);
//use the wrapper methos to insert to db
ArrayList<MobilePhone> skroutzPhonesUrls = wrapper.getPhonesUrls();
for(MobilePhone phone: skroutzPhonesUrls){
String urls = phone.getUrl();
updateSkrouztPs.setString(1, urls);
updateSkrouztPs.executeUpdate();
}
ArrayList<MobilePhone> skrouztPhonesNames = wrapper.getPhoneNames();
for(MobilePhone phone: skrouztPhonesNames){
String names = phone.getName();
updateSkrouztPs.setString(2, names);
updateSkrouztPs.executeUpdate();
}
//close the connection
conn.close();
System.out.println("Done!!");
}
catch(SQLException se){
//Handle errors for JDBC
se.printStackTrace();
}
catch (Exception e)
{
System.err.println("Got an exception!");
System.err.println(e.getMessage());
}
}
最佳答案
您的准备好的语句需要先设置两个字符串,然后才能调用executeUpdate。在每个循环中,您尝试设置 1,然后运行更新,这意味着 jdbc 最终会得到如下 sql 语句
INSERT INTO skrouzt(url,name) values ('your url',)
如果没有设置第二个值,则该语句无效。如果这些 url 和名称相互匹配,您应该通过一个循环成对插入数据。
按要求提供示例。请注意,这仅在列表长度相同的情况下才有效,但如果它们的长度不同,则需要以不同的方式设计数据库,以免它们成为同一个表中的两列。
for (int x = 0; x < skroutzPhonesUrls.size(); x++)
{
updateSkrouztPs.setString(1, skroutzPhonesUrls.get(x).getUrl());
updateSkrouztPs.setString(2, skrouztPhonesNames.get(x).getName());
updateSkrouztPs.executeUpdate();
}
关于java.sql.SQLException : No value specified for parameter 2 , 使用 JDBC 将 arraylist 插入数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29857216/
在 CSS 中,我从来没有真正理解为什么会发生这种情况,但每当我为某物分配 margin-top:50% 时,该元素就会被推到页面底部,几乎完全消失这一页。我假设 50% 时,该元素将位于页面的中间位
我想在 MongoDB 中使用 Grails2.5 中的“ElasticSearch”插件。我的“BuildConfig.groovy”文件是: grails.servlet.version = "3
我有一个我想要处理的 OHLC 股票报价数组。 Open High Low Close Volume 2003-01-05
我尝试创建一个PreparedStatement: stmt = conn.prepareStatement("SELECT POLBRP, POLTYP, POLNOP, INCPTP, TRMTH
我的目录结构如下: root libA CMakeLists.txt ClassA.cpp libB CMakeLists.txt ClassB.cpp s
我是 DBMS 的新手。我在每个用户的不同 csv 文件中都有车辆痕迹。格式:名称,时间戳,纬度,经度,randomId。例如:user0,2008-10-2309:42:25,441972.6942
我需要为我的应用程序打上烙印,并且只需要自定义少量图像,代码库是相同的,只是生成的常量很少。 由于aapt 允许指定许多资源目录,有没有办法在Eclipse .classpath 文件中指定res 目
我希望在我的应用程序中实现 JWT,因为我正在通过引用以下内容对其进行一些研发:https://stormpath.com/blog/jwt-java-create-verify .当我尝试通过提取声
我正在尝试通过设置限制获取数据并根据时间戳对数据进行排序,但在运行应用程序时崩溃并显示此错误消息: 查询无效。在指定顺序之前不得指定起点。 我不知道为什么会这样。如何解决? 我需要数据序列和排序。
我正在使用Elasticsearch和Tire进行Rails3项目。当我尝试运行Elastic-search时,安装它后,出现以下错误: The stack size specified is too
我创建了一个简单的函数来执行 Http PUT 请求 - public string checkIfUserExists(string userName) { var endP
Java 安全管理器允许通过定义如下子句来指定某些代码段的权限: ... grant codebase http://foo.bar.com/test.jar { permission java
这更像是一种验证。 在 Oracle/Java 教程页面上,例如 this , 我一直看到catch 旁边的“specify”就好像它是另一个语句在异常处理中具有一些功能。 据我所知,“catch o
本文整理了Java中org.batfish.specifier.ZoneNameRegexInterfaceSpecifier类的一些代码示例,展示了ZoneNameRegexInterfaceSpe
我正在尝试运行以下命令: ionic cordova run android --device 但我收到以下错误 BUILD FAILED in 3s (node:3956) Unha
在不包含 viewport 元标记的网页上,大多数移动浏览器会将页面上的部分或全部字体“提升”到大于 css 指定的大小。例如,在移动版 Safari 上,7px 的指定大小将提升为类似 12px 的
嗨,我不了解 keras fit_generator 文档。 我希望我的困惑是理性的。 有一个batch_size还有分批训练的概念。使用 model_fit() ,我指定一个 batch_size
我使用 IProviderSearchContext 在 Sitecore 8.1(Lucene 搜索)中搜索特定项目,并获得每个项目的两个版本(en、ar)。我的问题是:我是否必须为每个查询指定:
Except in a declaration of a constructor, destructor, or conversion function, at least one defining-
使用 GooglePageSpeed 分析在线商店(Shopware)导致每个图像上出现许多“未指定到期时间”的线条。 我想知道是因为网络服务器 (nginx) 在所有图像的响应中添加了 Last-M
我是一名优秀的程序员,十分优秀!