- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在创建一个简单的 Web 应用程序,并决定使用 Spring JdbcTemplate 类。但现在我遇到了 NoClassDefFoundError: org/springframework/jdbc/core/RowMapper 。
根据堆栈跟踪,第 32 行的 ControllerServlet 出现问题。其中:
productDAOImpl = new ProductDAOImpl(dataSource);
错误的原因可能是什么?我应该做什么来修复它?
Context Path:/webstore_war_exploded
Servlet Path:/ControllerServlet
Path Info:null
Query String:null
Stack Trace
java.lang.NoClassDefFoundError: org/springframework/jdbc/core/RowMapper
com.ncproject.webstore.controller.ControllerServlet.init(ControllerServlet.java:32)
javax.servlet.GenericServlet.init(GenericServlet.java:244)
io.undertow.servlet.core.LifecyleInterceptorInvocation.proceed(LifecyleInterceptorInvocation.java:117)
org.wildfly.extension.undertow.security.RunAsLifecycleInterceptor.init(RunAsLifecycleInterceptor.java:78)
io.undertow.servlet.core.LifecyleInterceptorInvocation.proceed(LifecyleInterceptorInvocation.java:103)
io.undertow.servlet.core.ManagedServlet$DefaultInstanceStrategy.start(ManagedServlet.java:250)
io.undertow.servlet.core.ManagedServlet.getServlet(ManagedServlet.java:171)
io.undertow.servlet.handlers.ServletHandler.handleRequest(ServletHandler.java:84)
io.undertow.servlet.handlers.security.ServletSecurityRoleHandler.handleRequest(ServletSecurityRoleHandler.java:62)
io.undertow.servlet.handlers.ServletDispatchingHandler.handleRequest(ServletDispatchingHandler.java:36)
org.wildfly.extension.undertow.security.SecurityContextAssociationHandler.handleRequest(SecurityContextAssociationHandler.java:78)
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
io.undertow.servlet.handlers.security.SSLInformationAssociationHandler.handleRequest(SSLInformationAssociationHandler.java:131)
io.undertow.servlet.handlers.security.ServletAuthenticationCallHandler.handleRequest(ServletAuthenticationCallHandler.java:57)
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
io.undertow.security.handlers.AbstractConfidentialityHandler.handleRequest(AbstractConfidentialityHandler.java:46)
io.undertow.servlet.handlers.security.ServletConfidentialityConstraintHandler.handleRequest(ServletConfidentialityConstraintHandler.java:64)
io.undertow.security.handlers.AuthenticationMechanismsHandler.handleRequest(AuthenticationMechanismsHandler.java:60)
io.undertow.servlet.handlers.security.CachedAuthenticatedSessionHandler.handleRequest(CachedAuthenticatedSessionHandler.java:77)
io.undertow.security.handlers.NotificationReceiverHandler.handleRequest(NotificationReceiverHandler.java:50)
io.undertow.security.handlers.AbstractSecurityContextAssociationHandler.handleRequest(AbstractSecurityContextAssociationHandler.java:43)
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
org.wildfly.extension.undertow.security.jacc.JACCContextIdHandler.handleRequest(JACCContextIdHandler.java:61)
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
io.undertow.server.handlers.PredicateHandler.handleRequest(PredicateHandler.java:43)
io.undertow.servlet.handlers.ServletInitialHandler.handleFirstRequest(ServletInitialHandler.java:292)
io.undertow.servlet.handlers.ServletInitialHandler.access$100(ServletInitialHandler.java:81)
io.undertow.servlet.handlers.ServletInitialHandler$2.call(ServletInitialHandler.java:138)
io.undertow.servlet.handlers.ServletInitialHandler$2.call(ServletInitialHandler.java:135)
io.undertow.servlet.core.ServletRequestContextThreadSetupAction$1.call(ServletRequestContextThreadSetupAction.java:48)
io.undertow.servlet.core.ContextClassLoaderSetupAction$1.call(ContextClassLoaderSetupAction.java:43)
io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
io.undertow.servlet.api.LegacyThreadSetupActionWrapper$1.call(LegacyThreadSetupActionWrapper.java:44)
io.undertow.servlet.handlers.ServletInitialHandler.dispatchRequest(ServletInitialHandler.java:272)
io.undertow.servlet.handlers.ServletInitialHandler.access$000(ServletInitialHandler.java:81)
io.undertow.servlet.handlers.ServletInitialHandler$1.handleRequest(ServletInitialHandler.java:104)
io.undertow.server.Connectors.executeRootHandler(Connectors.java:202)
io.undertow.server.HttpServerExchange$1.run(HttpServerExchange.java:805)
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
java.lang.Thread.run(Thread.java:745)
ControllerServlet.java
@WebServlet("/ControllerServlet")
public class ControllerServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
private ProductDAOImpl productDAOImpl;
@Resource(lookup = "java:/PostgresNC")
private DataSource dataSource;
@Override
public void init() throws ServletException {
super.init();
try {
productDAOImpl = new ProductDAOImpl(dataSource);
} catch (Exception exc) {
throw new ServletException(exc);
}
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try {
String theCommand = request.getParameter("command");
if (theCommand == null) {
theCommand = "PRODUCT_LIST";
}
switch (theCommand) {
case "PRODUCT_LIST":
listProducts(request, response);
break;
case "ADD_UPDATE":
addOrUpdateProduct(request, response);
break;
default:
listProducts(request, response);
}
} catch (Exception e) {
e.printStackTrace();
}
}
private void listProducts(HttpServletRequest request, HttpServletResponse response) throws Exception {
List<Product> products = productDAOImpl.getAllProducts();
request.setAttribute("PRODUCT_LIST", products);
RequestDispatcher dispatcher = request.getRequestDispatcher("/list-products.jsp");
dispatcher.forward(request, response);
}
private void addOrUpdateProduct(HttpServletRequest request, HttpServletResponse response) throws Exception {
// read product from the form
String idString = request.getParameter("productId");
String category = request.getParameter("category");
String description = request.getParameter("description");
String productName = request.getParameter("productName");
String price = request.getParameter("price");
BigDecimal priceBigDecimal = new BigDecimal(price);
String brand = request.getParameter("brand");
try {
int id = Integer.parseInt(idString.trim());
int numCategory = Integer.parseInt(category);
if(idString != null && category != null) {
Product theProduct = new Product(id, numCategory, description, productName, priceBigDecimal, brand);
// add the product to the database
productDAOImpl.saveOrUpdate(theProduct);
}
}
catch(NumberFormatException nfe) {
nfe.printStackTrace();
}
listProducts(request, response);
}
ProductDAOImpl.java
public class ProductDAOImpl implements ProductDAO {
private JdbcTemplate jdbcTemplate;
//private DataSource dataSource;
public ProductDAOImpl(DataSource dataSource) {
jdbcTemplate = new JdbcTemplate(dataSource);
}
@Override
public List<Product> getAllProducts() {
String sql = "SELECT * FROM products ORDER BY prod_id\n" +
"ASC";
List<Product> productList = jdbcTemplate.query(sql, new RowMapper<Product>() {
@Override
public Product mapRow(ResultSet resultSet, int rowNum) throws SQLException {
Product theProduct = new Product();
theProduct.setProd_id(resultSet.getInt("prod_id"));
theProduct.setCategory(resultSet.getInt("category"));
theProduct.setDescription(resultSet.getString("description"));
theProduct.setProductName(resultSet.getString("productName"));
theProduct.setPrice(resultSet.getBigDecimal("price"));
theProduct.setBrand("brand");
return theProduct;
}
});
return productList;
}
@Override
public void saveOrUpdate(Product newProduct) {
if (newProduct.getProd_id() > 0) {
// update
String sql = "UPDATE products "
+ "SET category=?, description=?, prod_name=?, price=?, brand=? "
+ "WHERE prod_id=?";
jdbcTemplate.update(sql, newProduct.getCategory(), newProduct.getDescription(),
newProduct.getProductName(), newProduct.getPrice(), newProduct.getBrand());
} else {
// insert
String sql = "INSERT INTO products (prod_id, category, description, prod_name, price, brand) "
+ "VALUES (?, ?, ?, ?, ?, ?)";
jdbcTemplate.update(sql, newProduct.getProd_id(), newProduct.getCategory(), newProduct.getDescription(),
newProduct.getProductName(), newProduct.getPrice(), newProduct.getBrand());
}
} }
最佳答案
所需的 JAR 文件不可用,因此您需要将其放在 CLASSPATH
中。您可以选择将相应的 JAR 文件添加到您的 CLASSPATH,或者作为替代方案,您可以从 here 下载 JAR 文件。 .
关于java - NoClassDefFound错误: org/springframework/jdbc/core/RowMapper,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41029708/
在 Spring 和 Hibernate 中,当我使用自定义 RowMapper 时,它会抛出以下错误 javax.servlet.jsp.JspException: java.lang.NoSuch
我定义了两个服务: Class cars model, year, mileage Class driver name, age, licExpDate 我已经在他们自己的服务中对每个查询进行了查
我使用 RowMapper 将数据库表映射到 java 对象 我的请求如下所示 SELECT SUM(quantity) FROM table1 t1 WHERE t1.x = 723834
我正在阅读 Spring in Action 并发现类似这样的内容,如果它是按照 RowMapper 的接口(interface),任何人都可以解释我们如何将 RowMapper 用作匿名类。文档。
我正在使用 SpringBatch 从 Oracle 读取数据并写入 ElasticSearch。 我的代码适用于静态查询。示例:select emp_id, emp_name from employ
我正在开发此应用程序来从现有 Oracle 数据库的单个表中获取数据。 这里我们得到了实体: public class OrdemDeServicoCount { private Long o
我在 JDBC 中使用 RowMappers 时遇到问题(尤其是 ParameterizedSingleColumnRowMapper): 我正在使用以下命令从数据库中查询现有 ID 列表: List
我有一个包含变量的域对象,作为来自 netezza 的值列表和另外 4 个变量,这些变量是普通变量,将使用行映射器从 oracle db 获取分配的值。 下面的语句抛出错误:类型不匹配:无法从 Lis
Spring 文档指出: "If the last two snippets of code actually existed in the same application, it would ma
我想知道 JdbcTemplate 和 RowMapper 是否支持复杂的对象检索。我在谷歌上找不到任何关于此事的信息(标准错误?)。 :( 示例: public class Person() {
我正在尝试实现 SO here 中提到的解决方案但是,我收到错误消息“Rowmapper is abstract cannot be instantiated”和“illegal start of e
我尝试四处寻找问题的答案,但未能解决。 我的应用程序在第 46 行的 RowMapper 类中抛出 NPE: orderLineRepository.sqlGetOrderLinesForOrder(
在 java 中,我会做类似下面的事情来迭代 resultset 并形成查询, public Map> fun(){ Map> map = new TreeMap>(); L
我的行映射器如下: private static final class UserRowMapper implements RowMapper { User user = new User()
当通过 SpringJdbcTemplate 从数据库中获取结果时,我到处都看到它们每次都在传递 RowMapper` 的新对象。 这是必需的吗?或者我们可以只使用一个对象并一次又一次地传递它吗? 例
问题是关于 RowMapper 在我们希望使用 spring jdbc 急切获取详细信息的主/详细场景中的最佳实践用法。 假设我们同时拥有 Invoice 和 InvoiceLine 类。 publi
我正在使用 JDBI 的 SQL 对象声明性 API 来映射包含一对多关系的对象: class Foo { private String id; private String name;
这是我的类(class) @Repository public class JdbcRolesDao implements RolesDao{ private JdbcTemplate jdbcTem
我正在使用 Spring Boot 构建连接到 Oracle DB 的 REST 服务。我也在使用 Spring JDBC。 我有以下代码: jdbcCall.declareParameters(ne
我使用 Spring jdbcTemplate 进行数据库获取调用,要获取的行数约为 100 万行。在结果集中迭代需要太多时间。调试行为后,我发现它像批处理一样处理一些行,然后等待一段时间,然后再次获
我是一名优秀的程序员,十分优秀!