- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我的 DAO 类:
public Map<String, String> issueOrUpdate(Map<String,String> employeeTempcardMap){
SlingDAO slingdao = new SlingDAO();
Map<String, String> issueOrUpdateMap = new HashMap<String, String>();
StringBuffer issueOrReturnTempcardQuery = new StringBuffer();
String empname="",functionkey="",tempcardnumber="",dateofissue="",dateofreturn="";
int empid=0,rowid=0,insertOrUpdateStatus=0;
Connection connection = slingdao.getConnection();
PreparedStatement issueOrReturnPS=null;
if (connection != null) {
try {
if(employeeTempcardMap.get("functionkey").toString().equals("issueTempCard")){
empid =Integer.parseInt(employeeTempcardMap.get("empid").toString()); //empname,tempcardnumber,dateofissue,rowid,dateofreturn
empname =employeeTempcardMap.get("empname").toString();
tempcardnumber =employeeTempcardMap.get("tempcardnumber").toString();
dateofissue =employeeTempcardMap.get("issuedate").toString();
//System.out.println("11111111111111111111111111111111111");
//System.out.println("empid : "+empid+" : empname: "+empname+" : tempcardnumber : "+tempcardnumber+": dateofissue "+dateofissue+"Status : "+applicationConstants.ISSUED);
issueOrReturnTempcardQuery.append(" INSERT INTO acct_tempcardhistory(empid,empname,tempcardnumber,tempcardstatus,issuedate,returndate) ");
issueOrReturnTempcardQuery.append(" VALUES(?,?,?,?,?,?) ");
}else{
dateofreturn = employeeTempcardMap.get("returndate").toString();
rowid = Integer.parseInt(employeeTempcardMap.get("rowid").toString());
issueOrReturnTempcardQuery.append(" UPDATE acct_tempcardhistory SET tempcardstatus=?,returndate=? ");
issueOrReturnTempcardQuery.append(" WHERE id ="+rowid);
}
issueOrReturnPS = connection.prepareStatement(issueOrReturnTempcardQuery.toString());
if(functionkey.equals("issueTempCard")){
//System.out.println("2222222222222222222222");
issueOrReturnPS.setInt(1, empid);
issueOrReturnPS.setString(2,empname.toString().trim());
issueOrReturnPS.setString(3, tempcardnumber.toString().trim());
issueOrReturnPS.setString(4, applicationConstants.ISSUED.toString().trim());
issueOrReturnPS.setString(5, dateofissue.toString().trim());
issueOrReturnPS.setString(6, "".toString().trim());
//issueOrUpdateMap.put("message","Temporary Card has been issued to "+empid);
}else {
issueOrReturnPS.setString(1, applicationConstants.RETURNED);
issueOrReturnPS.setString(2,dateofreturn);
//issueOrUpdateMap.put("message","Temporary Card has been Returned by "+empid);
}
insertOrUpdateStatus = issueOrReturnPS.executeUpdate();
System.out.println(insertOrUpdateStatus + "row(s) affected");
if(insertOrUpdateStatus >0){
issueOrUpdateMap.put("message","Temporary Card has been issued/Returned to "+empid);
}else{
issueOrUpdateMap.put("message","Temporary Card has not been issued/Returned to "+empid);
}
connection.close();
// connection.commit();
} catch (Exception ex) {
ex.printStackTrace();
issueOrUpdateMap.put("message","Temporary Card has not been issued/Returned to "+empid);
} finally {
try {
slingdao.closeConnection(connection, null, issueOrReturnPS);
} catch (Exception ex) {
ex.printStackTrace();
}
}
} else {
issueOrUpdateMap.put("dbmessage","Connection not Established. Please Contact Vendor");
}
return issueOrUpdateMap;
}
}
更新:
堆栈跟踪:
java.sql.SQLException: Statement parameter 3 not set.
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:910)
at com.mysql.jdbc.ServerPreparedStatement.serverExecute(ServerPreparedStatement.java:1045)
at com.mysql.jdbc.ServerPreparedStatement.executeInternal(ServerPreparedStatement.java:693)
at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1404)
at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1318)
at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1303)
at org.apache.tomcat.dbcp.dbcp.DelegatingPreparedStatement.executeUpdate(DelegatingPreparedS
tatement.java:105)
at org.apache.tomcat.dbcp.dbcp.DelegatingPreparedStatement.executeUpdate(DelegatingPreparedS
tatement.java:105)
at com.slingmedia.notifier.dao.TempCardDAO.issueOrUpdate(TempCardDAO.java:158)
at com.slingmedia.notifier.servlet.TempCardServlet.doPost(TempCardServlet.java:83)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:641)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.j
ava:305)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:999
)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.jav
a:565)
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:1812)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)
当我打印时,我看到了所有的值,但它仍然显示
java.sql.SQLException: Statement parameter <number> not set.
更新时同样有效,但插入数据时无效,我还将日期设置为字符串。
请指导我该怎么做或我在哪里弄错了?
问候
最佳答案
您忘记将 functionKey
设置为表达式的结果
employeeTempcardMap.get("functionkey").toString();
永远不要声明,尤其是永远不要初始化您的本地变量预先使用虚拟值。这只是掩盖了这样的编码问题。如果你有 final String functionKey = ...
,这种错误在理论上是不可能的。
关于java - 如何解决这个 java.sql.SQLException : Statement parameter <number> not set,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11518854/
在 go lang 中使用“If with a short statement”有什么好处。引用:go tour if v := math.Pow(x, n); v < lim { retur
完全错误: Warning: Unsafe statement written to the binary log using statement format since BINLOG_FORMAT
完全错误: Warning: Unsafe statement written to the binary log using statement format since BINLOG_FORMAT
我有三个存储过程 Sp1、Sp2 和 Sp3。 第一个 (Sp1) 将执行第二个 (Sp2) 并将返回的数据保存到 @tempTB1 中,第二个将执行第三个 (Sp3) 并将数据保存到 @tempTB
我已将 FLAG 设置为 1,并且正在执行 ARG 值应该仅为 DEV。但是我得到的是 ARG= DEV + CLIENTID 000023 // FLAG=1 000026 // I
我已将 FLAG 设置为 1,并且正在执行 ARG 值应该仅为 DEV。但是我得到的是 ARG= DEV + CLIENTID 000023 // FLAG=1 000026 // I
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
PMD告诉我 A switch with less than 3 branches is inefficient, use a if statement instead. 这是为什么呢?为什么是3?他
我刚开始学习 Racket,所以我仍在努力弄清楚这门语言的复杂性。我正在尝试在列表中实现我自己的搜索功能。如果函数找到它,则返回索引,否则返回 -1。 (define (find-index list
在 Kotlin 中,您可以使用类似于三元运算符的 if 语句。 我们可以选择做这样的事情: val x = if (isOdd) 1 else 2 但是如果我们有多个变量需要根据某些条件进行设置,那
在我的 Android 应用程序中,我尝试使用 XMLPullParser 使用以下代码读取 xml 文件: while (eventType != XmlPullParser.END_DOCUMEN
这个问题已经有答案了: Boolean expressions in Java (8 个回答) 已关闭 7 年前。 我遇到过一些情况,其中第一个似乎改变了 boolean 值,而第二个却没有!两者之间
我基本上想做的是: select * from request where id = 1 and created_at like (today's date); 但使用 Eloquent 。 我试过:
我不确定为什么会收到此代码。基本上我希望能够动态定位我的发射器,但是当我添加一个选项来检查位置并根据需要进行纠正时,我不断收到此错误。 添加的代码是 if (
何时使用语句而不是准备语句。我想语句用于没有参数的查询,但为什么不使用准备好的语句呢?对于没有参数的查询,哪个更快。 最佳答案 I suppose statement is used in queri
我必须创建一个表,如下所示 借款人(客户编号,贷款编号) 如果客户没有超过 3 笔贷款,则可以贷款。 我创建的表如下 create table borrower( customerno int(5),
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicates: Is "else if" faster than "switch() case"? What is the
typescript 版本 2.2.2 我在我的 UserRoutzr.ts 中写了这个要求 const users = require(path.join(process.cwd() + "/da
我有一个用 JPQL 编写的应用程序,它可以命中非常不同的查询(在不同的资源上)。 对于很多此类查询,我需要知道结果总数(计数),因为我没有应用任何 LIMIT/OFFSET 由于此查询的性质非常不同
我对以下 Java 语句感到困惑: ArtClass artClass0 = new ArtClass(); int int3 = 73; boolean boolean0 = artClass0.f
我是一名优秀的程序员,十分优秀!