ejb-jpa

本文介绍了一个基于EJB的应用实例,包括实体对象定义、实体管理接口及其实现,并详细展示了如何通过客户端调用EJB服务,以及JBoss数据源配置。

一ejb 服务端 基于ejb容器 ,客户端src下需要配置jndi配置文件

 

*实体对象

 

 

@Entity
public class Person implements Serializable {
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	@Id
	@GeneratedValue
	private int id;
	private String name;
	
}

 

 

*实体管理接口

 

 

import java.util.List;

public interface PersonManager {
	public void addPerson(Person person);
	public Person getPerson(int id);
	public Person getPerson2(int id);
	public List<Person> getPersons();
	public void updatePerson(Person person);
	public void deletePerson(int id);
	
	
}

 

*实体管理的实现

 

@Stateless
@Remote
@Local
public class PersonImpl implements PersonManager {
	@PersistenceContext(unitName="test")
	private EntityManager entityManager;
	public void addPerson(Person person) {
		entityManager.persist(person);
		//throw new RuntimeException("ddddddddddd");
	}
	public Person getPerson(int id) {
		//相当于hibernate中的load,是懒加载的
		Person p=entityManager.getReference(Person.class, id);
		System.out.println(p.getName());
		return p;
	}
	
	public Person getPerson2(int id){
		//相当于hibernate中的get
		Person p=entityManager.find(Person.class, id);
		return p;
	}
	
	public List<Person> getPersons(){
		return entityManager.createQuery(" from Person").getResultList();
	}
	
	public void updatePerson(Person person){
		entityManager.merge(person);
		
	}
	
	public void deletePerson(int id){
		
		entityManager.remove(getPerson(id));
	}
	
}

 

 

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="test" transaction-type="JTA">
  		<jta-data-source>java:/MySqlDS</jta-data-source>
  			<properties>
  			<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>
  			<property name="hibernate.show_sql" value="true"/>
  			<property name="hibernate.hbm2ddl.auto" value="update"/>
  		</properties>
	</persistence-unit>
  
</persistence>

  

 

二客户端

 

 

 

 

public class Client {

	/**
	 * @param args
	 */
	public static void main(String[] args) throws Exception {
		InitialContext context =new InitialContext();
		//UserTransaction  um=(UserTransaction )context.lookup("UserTransaction");
		//um.begin();
		PersonManager pm=(PersonManager)context.lookup("PersonImpl/remote");
		
		
//		Person p=new Person();
//		p.setName("www");
//		pm.addPerson(p);
		
		//Person p=pm.getPerson(5);
		//System.out.println(p.getName());
		
		
//		Person p=pm.getPerson2(5);
//		System.out.println(p.getName());
		
		//System.out.println(pm.getPersons().size());
		//um.commit();
		
//		Person p=new Person();
//		p.setId(5);
//		p.setName("xxxxxxxxxxxxx");
//		
//		pm.updatePerson(p);
		
	//	pm.deletePerson(5);
	}

}

 

 三 jboss 数据源的配置

 

 

jboss 安装目录D:\jboss-4.0.5.GA\server\default\deploy 下放入

 

mysql-ds.xml

 

 

<?xml version="1.0" encoding="UTF-8"?>

<!-- $Id: mysql-ds.xml 41016 2006-02-07 14:23:00Z acoliver $ -->
<!--  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/ejb</connection-url>
    <driver-class>com.mysql.jdbc.Driver</driver-class>
    <user-name>root</user-name>
    <password>bjsxt</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 (optional) -->
    <metadata>
       <type-mapping>mySQL</type-mapping>
    </metadata>
  </local-tx-datasource>
</datasources>

 

 

内容概要:本文介绍了一个基于Matlab的综合能源系统优化调度仿真资源,重点实现了含光热电站、有机朗肯循环(ORC)和电含光热电站、有机有机朗肯循环、P2G的综合能源优化调度(Matlab代码实现)转气(P2G)技术的冷、热、电多能互补系统的优化调度模型。该模型充分考虑多种能源形式的协同转换与利用,通过Matlab代码构建系统架构、设定约束条件并求解优化目标,旨在提升综合能源系统的运行效率与经济性,同时兼顾灵活性供需不确定性下的储能优化配置问题。文中还提到了相关仿真技术支持,如YALMIP工具包的应用,适用于复杂能源系统的建模与求解。; 适合人群:具备一定Matlab编程基础和能源系统背景知识的科研人员、研究生及工程技术人员,尤其适合从事综合能源系统、可再生能源利用、电力系统优化等方向的研究者。; 使用场景及目标:①研究含光热、ORC和P2G的多能系统协调调度机制;②开展考虑不确定性的储能优化配置与经济调度仿真;③学习Matlab在能源系统优化中的建模与求解方法,复现高水平论文(如EI期刊)中的算法案例。; 阅读建议:建议读者结合文档提供的网盘资源,下载完整代码和案例文件,按照目录顺序逐步学习,重点关注模型构建逻辑、约束设置与求解器调用方式,并通过修改参数进行仿真实验,加深对综合能源系统优化调度的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值