찾다
데이터 베이스MySQL 튜토리얼EJB 3.0开发指南之多表映射_MySQL
EJB 3.0开发指南之多表映射_MySQLJun 01, 2016 pm 02:06 PM
namepublicstring개발하다가이드

EJB

  在前面的例子中,我们每一个实体Bean只映射到数据库中的一张表上。事实上,一个实体Bean可以映射到多张表上。在一些需要字典表的项目上会经常用到,象以前我做过的项目,使用到很多国标规定的数据表。在我们下面这个例子中,性别作为一个字典表存在,学生这个实体将映射到学生信息表、性别表这两个表。

  从表可以使用@SecondaryTable来注释:

  @Target({TYPE}) @Retention(RUNTIME)

  public @interface SecondaryTable {
  String name();
  String catalog() default "";
  String schema() default "";
  JoinColumn[] join() default {};
  UniqueConstraint[] uniqueConstraints() default {};
  }

  这个注释可以指定表名、分类、schema、联合列、约束等。假如你使用多张表,你可以使用下面的注释来声明多张表:

  @SecondaryTable
  @Target({TYPE}) @Retention(RUNTIME)

  public @interface SecondaryTables {
  SecondaryTable[] value() default {};
  }

  这个例子主要有以下几个文件,这个例子主要实现了管理学生的功能。Student是一个实体Bean,这个Bean的name属性是一个类,也就是Name类,这个Name类就是一个依赖值对象。学生的性别映射到第二张表中。StudentDAOBean是一个无状态的会话Bean,用来调用实体Bean。和前面的例子一样,我们还是使用Client测试。

  这个例子和上一个例子基本相同,只是Student.java和Client有所不同。

   Student.java:实体Bean。

   Name.java:实体Bean所依赖的类。

   StudentDAO.java:会话Bean的业务接口

   StudentDAOBean.java:会话Bean的实现类

   Client.java:测试EJB的客户端类。

   jndi.properties:jndi属性文件,提供访问jdni的基本配置属性。

   Build.xml:ant 配置文件,用以编译、发布、测试、清除EJB。

  下面针对每个文件的内容做一个介绍。

  Student.java

  package com.kuaff.ejb3.secondary;

  import javax.ejb.Dependent;
  import javax.ejb.DependentAttribute;
  import javax.ejb.Column;
  import javax.ejb.Entity;
  import javax.ejb.GeneratorType;
  import javax.ejb.Id;
  import javax.ejb.Table;
  import javax.ejb.SecondaryTables;
  import javax.ejb.SecondaryTable;
  import javax.ejb.JoinColumn;

  @Entity
  @Table(name = "STUDENT")
  @SecondaryTables({
  @SecondaryTable(name = "GENDER", join = {@JoinColumn(name = "GENDER_ID")})
  })

  public class Student implements java.io.Serializable
  {
  private int id;
  private Name name;
  private String grade;
  private String email;
  private String gender;

  @Id(generate = GeneratorType.AUTO)

  public int getId()
  {
  return id;
  }

  public void setId(int id)
  {
  this.id = id;
  }

  public void setName(Name name)
  {
  this.name = name;
  }

  @Dependent({ @DependentAttribute(name = "first", column ={ @Column(name = "FIRST") }),

  @DependentAttribute(name = "last", column ={ @Column(name = "LAST") }) })

  public Name getName()
  {
  return name;
  }

  public void setGrade(String grade)
  {
  this.grade = grade;
  }

  @Column(name = "GRADE")

  public String getGrade()
  {
  return grade;
  }

  public void setEmail(String email)
  {
  this.email = email;
  }

  @Column(name = "EMAIL")

  public String getEmail()
  {
  return email;
  }

  public void setGender(String gender)
  {
  this.gender = gender;
  }

  @Column(name = "gender", secondaryTable = "GENDER")

  public String getGender()
  {
  return gender;
  }

  }


  Student.java实现了Student实体Bean,它提供学生的基本情况。在类上声明上加上了第二张表的注释:

  @SecondaryTables({
  @SecondaryTable(name = "GENDER", join = {@JoinColumn(name = "GENDER_ID")})
  })

  在gender属性上加上了映射第二张的注释:

  @Column(name = "gender", secondaryTable = "GENDER")

  Client.java

  package com.kuaff.ejb3.secondary;

  import javax.naming.InitialContext;

  import javax.naming.NamingException;

  import java.util.List;


  public class Client
  {
  public static void main(String[] args) throws NamingException

  {

  InitialContext ctx = new InitialContext();

  StudentDAO dao = (StudentDAO) ctx.lookup(StudentDAO.class.getName());

  int id = dao.create("晁","岳攀","8","smallnest@kuaff.com","男");

  dao.create("朱","立焕","6","zhuzhu@kuaff.com","女");



  List list = dao.findAll();

  for(Object o:list)

  {

  Student s = (Student)o;

  System.out.printf("%s%s的性别:%s%n",s.getName().getFirst(),s.getName().getLast(),s.getGender());

  dao.evict(s);

  }

  这个客户端增加学生的分数,并且测试显示这个学生的email。

  请运行{$JBOSS_HOME}/bin目录下的run.bat: run

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
在Go语言中使用Elastic Stack:完整指南在Go语言中使用Elastic Stack:完整指南Jun 17, 2023 am 10:42 AM

在Go语言中使用ElasticStack:完整指南ElasticStack是一个开源工具集,它为搜索、分析和可视化大量数据提供了强大的支持。该工具集由四个主要组件组成:Elasticsearch、Logstash、Kibana和Beats。其中,Elasticsearch是一个分布式的搜索和分析引擎,能够快速地执行搜索、分析和聚合操作。Logstash是

在Go语言中使用AWS SDK:完整指南在Go语言中使用AWS SDK:完整指南Jun 17, 2023 am 09:40 AM

AWS(AmazonWebServices)是一家全球领先的云计算提供商,为企业和个人提供各种云计算服务。随着云计算技术的发展,越来越多的开发者开始使用AWS来进行开发、测试和部署他们的应用程序。Go语言是一门非常流行的编程语言,尤其适合构建高性能和可扩展的云原生应用程序。AWS提供了适用于Go语言的SDK(SoftwareDevelopmentKi

PHP中的安全审计指南PHP中的安全审计指南Jun 11, 2023 pm 02:59 PM

随着Web应用程序的日益普及,安全审计也变得越来越重要。PHP是一种广泛使用的编程语言,也是很多Web应用程序的基础。本文将介绍PHP中的安全审计指南,以帮助开发人员编写更加安全的Web应用程序。输入验证输入验证是Web应用程序中最基本的安全特性之一。虽然PHP提供了许多内置函数来对输入进行过滤和验证,但这些函数并不能完全保证输入的安全性。因此,开发人员需要

在Go语言中使用AWS S3:完整指南在Go语言中使用AWS S3:完整指南Jun 17, 2023 am 08:21 AM

近年来,随着云计算技术的发展,许多企业开始转向使用云存储服务来存储和管理自己的数据。其中,AWSS3(AmazonWebServicesSimpleStorageService)是一种备受欢迎的选择。作为AWS的核心服务之一,S3提供了高可用性、高性能、可扩展和安全的存储服务。在这篇文章中,我们将深入探讨如何在Go语言中使用AWSS3。安装AW

PHP中的ERP系统开发指南PHP中的ERP系统开发指南May 21, 2023 am 08:22 AM

随着现代企业的发展,ERP系统的重要性也越来越凸显出来。ERP系统可以帮助企业集成和管理计划、客户关系、供应链、人力资源等方面的数据和业务流程。PHP作为一种流行的编程语言,也可以用于开发ERP系统。在本文中,我们将分享一些PHP中的ERP系统开发指南。确定ERP系统的需求在开始开发ERP系统之前,您需要确定自己的ERP系统所需要的功能。根据你的企业的运营方

如何使用 wmic 快速列出所有 Windows 进程 [教程]如何使用 wmic 快速列出所有 Windows 进程 [教程]Jun 02, 2023 pm 03:13 PM

当您在处理各种重要项目并且性能是关键字时,必须准确了解后台运行的进程。特别是如果上述一个或多个过程影响您当前的工作,或者您可以只使用额外的果汁。准确地找出您的设备仍在后台运行的内容非常容易。您可以使用wmic工具在几秒钟内获得所需的所有信息。怎么样,你问?我们将在本文中向您展示这一点,因此您可以方便地获得这些信息以供将来参考。如何使用wmic了解后台进程?实际上,您可以在命令提示符窗口中输入许多有用的命令,前提是您以管理员权限打开它,这些命令可以提供宝贵的信息。了解后台进程以及收集系统信息(BI

PHP中的音频操作指南PHP中的音频操作指南May 20, 2023 pm 09:42 PM

PHP作为一种广泛使用的服务器端语言,在许多Web应用程序中扮演着重要的角色。音频处理是一个很常见的需求,例如音乐网站和音频产品销售网站等。在本文中,将为读者介绍如何在PHP中操作音频文件。一、了解音频格式在PHP中操作音频文件前,需要先了解音频文件格式。常见的音频格式有MP3、WAV、OGG、FLAC等。不同的格式有不同的音频编码算法和数据格式。例如,MP

在Go语言中使用AWS IAM:完整指南在Go语言中使用AWS IAM:完整指南Jun 17, 2023 pm 03:39 PM

AWS(AmazonWebServices)作为云计算业界的领头羊,提供了方便而强大的云计算服务,使得企业可以轻松地构建和管理自己的IT基础设施,并获得更好的可扩展性、灵活性和低成本。而IAM(IdentityandAccessManagement)是AWS中的重要服务之一,负责管理用户(包括人员、应用、服务等)的身份和访问权限,保障AWS资源的安

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경