2

我正在使用 GlassFish v3。在类中声明了以下字段:

@Resource
private javax.sql.DataSource _data_source;

在 web.xml 中声明了以下内容:

<data-source>
  <name>java:app/env/data</name>
  <class-name>com.mysql.jdbc.Driver</class-name>
  <server-name>localhost</server-name>
  <port-number>3306</port-number>       
  <user>myUser</user>                           
  <password>myPass</password>
</data-source>

在运行时 _data_source 为空。我究竟做错了什么?

4

4 回答 4

2

你能试试这个:

@Resource(lookup = "java:app/env/data")
private DataSource _data_source;

也可以看看

于 2010-06-12T23:40:26.870 回答
1

除了 Pascal 的回答:如果通过注解注入不起作用(没有发生异常,字段只是空),问题通常是旧的部署描述符版本。对于 Glasfish v3,您可以使用:

<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
于 2010-06-12T23:55:50.613 回答
1

尝试使用:

@Resource(lookup="java:app/env/data")
private DataSource _data_source;
于 2010-07-30T13:29:09.997 回答
0

像这样的东西应该可以工作,没有xml:

@Resource(name="jdbc/__default")
private DataSource ds
...
Connection con = null {
try {
  con = ds.getConnection();
  ...
} finally {
  if (con != null) con.close()
}
于 2010-06-14T20:35:18.200 回答