Rumah pangkalan data tutorial mysql EJB 3.0开发指南之多表映射_MySQL

EJB 3.0开发指南之多表映射_MySQL

Jun 01, 2016 pm 02:06 PM
name public string membangun panduan

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

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Panduan untuk mematikan VBS dalam Windows 11 Panduan untuk mematikan VBS dalam Windows 11 Mar 08, 2024 pm 01:03 PM

Dengan pelancaran Windows 11, Microsoft telah memperkenalkan beberapa ciri dan kemas kini baharu, termasuk ciri keselamatan yang dipanggil VBS (Virtualization-basedSecurity). VBS menggunakan teknologi virtualisasi untuk melindungi sistem pengendalian dan data sensitif, dengan itu meningkatkan keselamatan sistem. Walau bagaimanapun, bagi sesetengah pengguna, VBS bukanlah ciri yang diperlukan malah boleh menjejaskan prestasi sistem. Oleh itu, artikel ini akan memperkenalkan cara untuk mematikan VBS dalam Windows 11 untuk membantu

Menyediakan bahasa Cina dengan VSCode: Panduan Lengkap Menyediakan bahasa Cina dengan VSCode: Panduan Lengkap Mar 25, 2024 am 11:18 AM

Persediaan VSCode dalam Bahasa Cina: Panduan Lengkap Dalam pembangunan perisian, Visual Studio Code (VSCode ringkasnya) ialah persekitaran pembangunan bersepadu yang biasa digunakan. Bagi pembangun yang menggunakan bahasa Cina, menetapkan VSCode kepada antara muka Cina boleh meningkatkan kecekapan kerja. Artikel ini akan memberi anda panduan lengkap, memperincikan cara menetapkan VSCode kepada antara muka Cina dan menyediakan contoh kod khusus. Langkah 1: Muat turun dan pasang pek bahasa Selepas membuka VSCode, klik di sebelah kiri

Empat alat pengaturcaraan berbantukan AI yang disyorkan Empat alat pengaturcaraan berbantukan AI yang disyorkan Apr 22, 2024 pm 05:34 PM

Alat pengaturcaraan berbantukan AI ini telah menemui sejumlah besar alat pengaturcaraan berbantukan AI yang berguna dalam peringkat pembangunan AI yang pesat ini. Alat pengaturcaraan berbantukan AI boleh meningkatkan kecekapan pembangunan, meningkatkan kualiti kod dan mengurangkan kadar pepijat Ia adalah pembantu penting dalam proses pembangunan perisian moden. Hari ini Dayao akan berkongsi dengan anda 4 alat pengaturcaraan berbantukan AI (dan semua menyokong bahasa C# saya harap ia akan membantu semua orang). https://github.com/YSGStudyHards/DotNetGuide1.GitHubCopilotGitHubCopilot ialah pembantu pengekodan AI yang membantu anda menulis kod dengan lebih pantas dan dengan sedikit usaha, supaya anda boleh lebih memfokuskan pada penyelesaian masalah dan kerjasama. Git

Ketahui cara membangunkan aplikasi mudah alih menggunakan bahasa Go Ketahui cara membangunkan aplikasi mudah alih menggunakan bahasa Go Mar 28, 2024 pm 10:00 PM

Tutorial aplikasi mudah alih pembangunan bahasa Go Memandangkan pasaran aplikasi mudah alih terus berkembang pesat, semakin ramai pembangun mula meneroka cara menggunakan bahasa Go untuk membangunkan aplikasi mudah alih. Sebagai bahasa pengaturcaraan yang mudah dan cekap, bahasa Go juga telah menunjukkan potensi yang kukuh dalam pembangunan aplikasi mudah alih. Artikel ini akan memperkenalkan secara terperinci cara menggunakan bahasa Go untuk membangunkan aplikasi mudah alih dan melampirkan contoh kod khusus untuk membantu pembaca bermula dengan cepat dan mula membangunkan aplikasi mudah alih mereka sendiri. 1. Persediaan Sebelum memulakan, kita perlu menyediakan persekitaran dan alatan pembangunan. kepala

Pengaturcara AI manakah yang terbaik? Terokai potensi Devin, Tongyi Lingma dan ejen SWE Pengaturcara AI manakah yang terbaik? Terokai potensi Devin, Tongyi Lingma dan ejen SWE Apr 07, 2024 am 09:10 AM

Pada 3 Mac 2022, kurang daripada sebulan selepas kelahiran pengaturcara AI pertama di dunia, Devin, pasukan NLP Universiti Princeton membangunkan pengaturcara AI sumber terbuka ejen SWE. Ia memanfaatkan model GPT-4 untuk menyelesaikan isu secara automatik dalam repositori GitHub. Prestasi ejen SWE pada set ujian bangku SWE adalah serupa dengan Devin, mengambil purata 93 saat dan menyelesaikan 12.29% masalah. Dengan berinteraksi dengan terminal khusus, ejen SWE boleh membuka dan mencari kandungan fail, menggunakan semakan sintaks automatik, mengedit baris tertentu dan menulis serta melaksanakan ujian. (Nota: Kandungan di atas adalah sedikit pelarasan bagi kandungan asal, tetapi maklumat utama dalam teks asal dikekalkan dan tidak melebihi had perkataan yang ditentukan.) SWE-A

Adakah PHP front-end atau back-end dalam pembangunan web? Adakah PHP front-end atau back-end dalam pembangunan web? Mar 24, 2024 pm 02:18 PM

PHP tergolong dalam bahagian belakang dalam pembangunan web. PHP ialah bahasa skrip sebelah pelayan, terutamanya digunakan untuk memproses logik sebelah pelayan dan menjana kandungan web dinamik. Berbanding dengan teknologi bahagian hadapan, PHP lebih banyak digunakan untuk operasi bahagian belakang seperti berinteraksi dengan pangkalan data, memproses permintaan pengguna dan menjana kandungan halaman. Seterusnya, contoh kod khusus akan digunakan untuk menggambarkan aplikasi PHP dalam pembangunan back-end. Mula-mula, mari kita lihat contoh kod PHP mudah untuk menyambung ke pangkalan data dan menanyakan data:

Panduan konfigurasi direktori pemasangan PHP7 Panduan konfigurasi direktori pemasangan PHP7 Mar 11, 2024 pm 12:18 PM

Panduan Konfigurasi Direktori Pemasangan PHP7 PHP ialah bahasa skrip sebelah pelayan yang popular digunakan untuk membangunkan halaman web dinamik. Pada masa ini, versi terbaharu PHP ialah PHP7, yang memperkenalkan banyak ciri baharu dan pengoptimuman prestasi dan merupakan versi pilihan untuk banyak tapak web dan aplikasi. Apabila memasang PHP7, adalah sangat penting untuk mengkonfigurasi direktori pemasangan dengan betul Artikel ini akan memberikan anda panduan terperinci untuk mengkonfigurasi direktori pemasangan PHP7, dengan contoh kod khusus. Untuk memuat turun PHP7 terlebih dahulu, anda perlu memuat turunnya dari laman web rasmi PHP (https://www.

Memahami VSCode: Untuk apa alat ini digunakan? Memahami VSCode: Untuk apa alat ini digunakan? Mar 25, 2024 pm 03:06 PM

"Memahami VSCode: Untuk apa alat ini digunakan?" 》Sebagai pengaturcara, sama ada anda seorang pemula atau pembangun berpengalaman, anda tidak boleh melakukannya tanpa menggunakan alat penyuntingan kod. Di antara banyak alat penyuntingan, Kod Visual Studio (pendek kata VSCode) sangat popular di kalangan pembangun sebagai penyunting kod sumber terbuka, ringan dan berkuasa. Jadi, untuk apa sebenarnya VSCode digunakan? Artikel ini akan menyelidiki fungsi dan kegunaan VSCode dan menyediakan contoh kod khusus untuk membantu pembaca

See all articles