Myeclipse开发EJB3.0(实体bean)

百度了很多资料都没有涉及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();
	}
%>




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值