- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试四处寻找问题的答案,但未能解决。
我的应用程序在第 46 行的 RowMapper 类中抛出 NPE:
orderLineRepository.sqlGetOrderLinesForOrder(rs.getInt("orderId"))
有人可以帮我解决这个问题吗?我不太确定它出了什么问题。
这是类(class)的副本:
@Repository("orderRepository")
public class OrderRepository {
@Autowired
private JdbcTemplate jdbc;
public Order sqlGetOrderByOrderId(int orderId) {
String sql = "SELECT om.orderId, om.orderRef, om.orderChannel, "
+ "om.orderCreated, om.orderCompleted, om.orderStatus, "
+ "c.customerId, c.name, c.email, c.phoneNumber, "
+ "a.addressId, a.houseNameNumber, a.streetName, "
+ "a.addressLine2, a.addressLine3, a.addressLine4, "
+ "a.postCode, a.countryCode "
+ "FROM OrderMain om "
+ "INNER JOIN Customer c ON om.customerId=c.customerId "
+ "INNER JOIN Address a ON om.addressId=a.addressId "
+ "WHERE om.orderId=?";
return jdbc.queryForObject(sql, new Object[] {orderId}, new OrderRowMapper());
}
}
订单行映射器:
public class OrderRowMapper implements RowMapper<Order> {
@Autowired
private OrderLineRepository orderLineRepository;
public Order mapRow(ResultSet rs, int rowNum) throws SQLException {
Customer customer = new Customer();
customer.setCustomerId(rs.getInt("customerId"));
customer.setName(rs.getString("name"));
customer.setEmail(rs.getString("email"));
customer.setPhoneNumber(rs.getString("phoneNumber"));
Address address = new Address();
address.setAddressId(rs.getInt("addressId"));
address.setHouseNameNumber(rs.getString("houseNameNumber"));
address.setStreetName(rs.getString("streetName"));
address.setAddressLine2(rs.getString("addressLine2"));
address.setAddressLine3(rs.getString("addressLine3"));
address.setAddressLine4(rs.getString("addressLine4"));
address.setPostcode(rs.getString("postcode"));
address.setCountryCode(rs.getString("countryCode"));
Order order = new Order(
rs.getInt("orderId"),
rs.getString("orderRef"),
rs.getString("orderChannel"),
rs.getTimestamp("orderCreated"),
rs.getTimestamp("orderCompleted"),
OrderStatus.orderStatusGetById(rs.getInt("orderStatus")),
customer,
address,
orderLineRepository.sqlGetOrderLinesForOrder(rs.getInt("orderId"))
);
return order;
}
}
这正在调用我的 orderLineRepository,如下:
@Repository("orderLineRepository")
public class OrderLineRepository {
@Autowired
private JdbcTemplate jdbc;
@Autowired
private NamedParameterJdbcTemplate namedJdbc;
public List<OrderLine> sqlGetOrderLinesForOrder(int orderId) {
Map<String, Object> params = new HashMap<String, Object>();
params.put("orderId", orderId);
String sql = "SELECT itemId, orderQty, cancelledQty, "
+ "despatchedQty, replacedQty, refundedQty, "
+ "orderLineStatus, orderValue, unitValue, "
+ "shippingCost "
+ "FROM OrderLine "
+ "WHERE orderId=:orderId";
return namedJdbc.query(sql, params, new OrderLineRowMapper());
}
public List<OrderLine> sqlGetAllOrderLines() {
String sql = "SELECT itemId, orderQty, cancelledQty, "
+ "despatchedQty, replacedQty, refundedQty, "
+ "orderLineStatus, orderValue, unitValue, "
+ "shippingCost "
+ "FROM OrderLine";
return jdbc.query(sql, new OrderLineRowMapper());
}
}
如果需要,这是我的 OrderLineRowMapper:
public class OrderLineRowMapper implements RowMapper<OrderLine> {
public OrderLine mapRow(ResultSet rs, int rowNum) throws SQLException {
OrderLine orderLine = new OrderLine();
orderLine.setItemId(rs.getInt("itemId"));
orderLine.setOrderQty(rs.getInt("orderQty"));
orderLine.setCancelledQty(rs.getInt("cancelledQty"));
orderLine.setDespatchedQty(rs.getInt("despatchedQty"));
orderLine.setReplacedQty(rs.getInt("replacedQty"));
orderLine.setRefundedQty(rs.getInt("refundedQty"));
orderLine.setOrderLineStatus(OrderLineStatus.orderLineStatusGetById(rs.getInt("orderLineStatus")));
orderLine.setOrderValue(rs.getDouble("orderValue"));
orderLine.setUnitValue(rs.getDouble("unitValue"));
orderLine.setShippingCost(rs.getDouble("shippingCost"));
return orderLine;
}
}
预先感谢您提供的任何帮助!
最佳答案
当您自己创建对象时,您如何期望 Spring Autowiring 任何内容?
return namedJdbc.query(sql, params, new OrderLineRowMapper());
Spring 只能将 Bean 注入(inject)到其他 Spring 管理的 Bean 中。
让 Spring 创建一个 OrderLineRowMapper
bean 并注入(inject)并在您的 OrderLineRepository
类中使用它。
关于java - Spring RowMapper NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20575930/
我正在将我的模板代码移植到 XTend。在某些时候,我在测试用例中有这种类型的条件处理: @Test def xtendIfTest() { val obj = new FD if (
我是新来的 kotlin , 当我开始 Null Safety 时,我对下面的情况感到困惑. There's some data inconsistency with regard to initia
我的应用程序一直在各种Android版本中保持良好状态。我有用户在Android 4.3、5.0、5.1和6.0上正常运行。但是,具有S7 Edge的用户刚刚更新了Android 7.0,将文本粘贴到
我使用的是最新版本的 LWUIT (1.5)。我在资源编辑器中设计了我的表单,然后将代码生成到 netbeans。问题是如果我想访问除表单之外的任何对象,我会收到此错误: java.lang.Null
更新: 我在 Fedora 21 上运行它。 SonarQube - 5.0。 SonarQube Runner - 2.4 更新 2:Findbugs v3.1,Java 插件 v2.8 更新3:
RecupData 我的类仅在 web 中返回 NullPointerException。我连接到 pgsql db 8.3.7 - 该脚本在“控制台”syso 中运行良好 - 但引发了测试 Web
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
每次运行此 jsp 时,都会收到以下错误异常: org.apache.jasper.JasperException: java.lang.NullPointerException root cause
Kotlin 在编译时有一个出色的 null 检查,使用分离到“可空?”和“不可为空”的对象。它有一个 KAnnotator 来帮助确定来自 Java 的对象是否可以为空。但是,如果 not-null
我有一个布局将显示一个TextView,用于显示一个滴答时间。我遵循了此链接中的代码 How to Display current time that changes dynamically for
Elasticsearch 1.4.1版(“lucene_version”:“4.10.2”) 我有一个像这样的文件: $ curl 'http://localhost:9200/blog/artic
这是我从另一个类调用函数的方法Selenium 设置已定义。 public void Transfer() throws Exception { System.out.println("\nTrans
我试图在主类中使用我在此类中创建的函数,但它崩溃并显示“警告:无法在根 0 处打开/创建首选项根节点 Software\JavaSoft\Prefsx80000002。 Windows RegCrea
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 我有一个 Java 代码,它将
我声明了两张牌: Card card1 = new Card('3', Card.Suit.clubs); Card card2 = new Card('T', Card.Suit.diamonds)
我编写了一段代码来解码 Base64 图像并在 javafx 中表示该图像。在我的 url base64 代码中不断变化。这就是我在 javafx 代码中使用任务的原因。但我收到错误:java.lan
我正在尝试使用 arrayList 的 arrayList 在 Java 中实现图形。 每当调用 addEdge 函数时,我都会收到 NullPointerException 。我似乎无法弄清楚为什么
我是 Java/android 的新手,所以很多这些术语都是外国的,但我愿意学习。我不打算详细介绍该应用程序,因为我认为它不相关。我目前的问题是,我使用了博客中的教程和代码 fragment ,并使我
我正在开发一个 Android 应用程序来在 Android developer guide 的帮助下录制视频.我程序上的所有代码都与此页面相同。 我在 之外定义了权限标签。 当应
我是一名优秀的程序员,十分优秀!