百度了很多资料都没有涉及myeclipse10配置ejb3.0的,只好自已凭着经验来配置了,结果ok
myeclipse开发ejb觉得挺方便的,配置就不说的,贴源码
创建会话bean
package com.java;
import java.util.List;
public interface BeanRemote {
public void insertStu(Student stu);
public void delStu(Integer id);
public void modifyStu(Student stu);
public Student findStuById(Integer id);
public List<Student> getAllStuList();
public void SayHello();
}
实现接口中方法
package com.java;
import java.util.List;
import javax.ejb.Remote;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;
@Remote(BeanRemote.class)
@Stateless
public class Bean implements BeanRemote {
@PersistenceContext(unitName = "EJBBean")
protected EntityManager em;
@Override
public void insertStu(Student stu) {
em.persist(stu);
}
//每次执行先调用该方法用于测试是否,接口绑定成功
@Override
public void SayHello() {
System.out.println("Hello word...");
}
@Override
public void delStu(Integer id) {
Student stu = em.find(Student.class, id);
if(stu!=null){em.remove(stu);}
}
@Override
public void modifyStu(Student stu) {
em.merge(stu);
}
@Override
public Student findStuById(Integer id) {
return em.find(Student.class, id);
}
@SuppressWarnings("unchecked")
@Override
public List<Student> getAllStuList() {
Query query = em.createQuery("select s from Student s order by s.id");
return (List<Student>)query.getResultList();
}
}
Student的实体类
package com.java;
import java.io.Serializable;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name = "Student")
public class Student implements Serializable{
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Integer id;
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Student() {
}
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
public int hashCode() {
return (this.id == null) ? 0 : this.id.hashCode();
}
public boolean equals(Object object) {
if (object instanceof Student) {
final Student obj = (Student) object;
return (this.id != null) ? this.id.equals(obj.id)
: (obj.id == null);
}
return false;
}
}
然后在deploy下配置mysql的数据源
<?xml version="1.0" encoding="UTF-8"?>
<!-- $Id: mysql-ds.xml 63175 2007-05-21 16:26:06Z rrajesh $ -->
<!-- Datasource config for MySQL using 3.0.9 available from:
http://www.mysql.com/downloads/api-jdbc-stable.html
-->
<datasources>
<local-tx-datasource>
<jndi-name>MySqlDS</jndi-name>
<connection-url>jdbc:mysql://localhost:3306/test</connection-url>
<driver-class>com.mysql.jdbc.Driver</driver-class>
<user-name>root</user-name>
<password>111111</password>
<exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</exception-sorter-class-name>
<!-- should only be used on drivers after 3.22.1 with "ping" support
<valid-connection-checker-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLValidConnectionChecker</valid-connection-checker-class-name>
-->
<!-- sql to call when connection is created
<new-connection-sql>some arbitrary sql</new-connection-sql>
-->
<!-- sql to call on an existing pooled connection when it is obtained from pool - MySQLValidConnectionChecker is preferred for newer drivers
<check-valid-connection-sql>some arbitrary sql</check-valid-connection-sql>
-->
<!-- corresponding type-mapping in the standardjbosscmp-jdbc.xml -->
<metadata>
<type-mapping>mySQL</type-mapping>
</metadata>
</local-tx-datasource>
</datasources>
配置persistence.xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0">
<persistence-unit name="EJBBean" transaction-type="JTA">
<jta-data-source>java:/MySqlDS</jta-data-source>
<properties>
<property name="hibernate.jdbc.fetch_size" value="18"/>
</properties>
</persistence-unit>
</persistence>
让后就可以部署到jboss4中了
接着测试客服端
<%@ page language="java" import="java.util.*,com.java.*,javax.naming.*"
pageEncoding="ISO-8859-1"%>
<%
try {
InitialContext ct = new InitialContext();
BeanRemote bean = (BeanRemote) ct.lookup("Bean/remote");
Student std = new Student();
std.setName("Java");
bean.insertStu(std);
bean.SayHello();
} catch (Exception ex) {
ex.printStackTrace();
}
%>