Bom é isso vamos a mais um post e desta vez vamos falar as anotações usando o Hibernate.
Antes de mais nada vale ressaltar que para você configurar o Hibernate na sua aplicação não necessariamente você precisa usar JPA, isto é, annotation ou anotações. As configurações do banco poderiam muito bem serem feitas usando os arquivos hbm.xml, mas como isso (no meu caso) é muito chato de fazer vamos para as annotation.
Para quem tiver o interesse ou já usa mas não sabe, o Hibernate oferece uma API que serve para eliminar de vez o uso dos complexos arquivos hbm.xml para simplificar o desenvolvimento das aplicações e facilitar a manutenção. Isso graças a vantagem de que toda essa configuração fica na classe e não em arquivos separados que em muitos caso não é de fácil entendimento.
1.
@Id : é a anotação de atributo que o identifica como uma chave primaria.
2.
@GeneratedValue : é a anotação de atributo que faz com que a chave primaria tenha seu valor gerado automaticamente. em geral essa anotação vem acompanhada por
@Id.
3.
@Entity : é uma anotação de classe que diz que o objeto em questão possui uma tabela associada no banco de dados.
4.
@Table (name=
"table") : anotação de classe que diz o nome da tabela a qual o objeto está mapeado. Ela não é obrigatória e por tanto se não for declara a tabela terá p mesmo nome do objeto.
5.
@Column (name=
"column", nullable=
false, length=32) : anotação de atributo que o relaciona a uma coluna da tabela atribuindo as características da coluna não poder conter um valor nulo e o seu tamanho não pode passar de 32 bytes. Essa anotação não é obrigatória e por tanto se não for declara a coluna terá o mesmo nome do atributo, podendo conter valor nulo de tamanho definido no banco.
6.
@Lob : anotação de atributo que identifica que ele é um tipo Clob ou Blob.
7.
@OneToMany (mappedBy=
"order", cascade=CascadeType.ALL, fech=FetchType.LAZY)
@OrderBy (value=
"id ASC")
- anotações de atributo que declaram que é uma relação de 1-N. A anotação @OrderBy não é obrigatória.
@ManyToOne (cascade=CascadeType.REFRESH, optional=
false)
@JoinColumn (name=
"order_id")
- anotação de atributo que declara que é uma relação de N-1. A anotação @JoinColumn só é necessário quando não houver explicitamente um campo que una as duas tabelas.
8.
@Temporal (value=TemporalType.DATE) : anotação de atributo que descreve a precisão esperada no banco de dados.
9.
@OneToOne (optional=
true, cascade=CascadeType.ALL, mappedBy=
"person") : anotação de atributo que o associa a um objeto também mapeado por
@Entity. Há casos em que é necessário utilizar a anotação
@JoinColumn para dizer explicitamente a associação, exemplo:
@OneToOne (optional=
false, cascade=CascadeType.ALL, mappedBy=
"person")
@JoinColumn (name=
"Person_ID", referencedColumnName=
"personid", unique=
true)
- anotação de atributo 1-1.
10.
@ManyToMany (mappedBy=
"students") : anotação de atributo que declara que é uma relação de N-N. Há casos em que é necessário utilizar o
@JoinColumn para dizer explicitamente a associação, exemplo:
@ManyToMany (cascade=CascadeType.PERSIST, fetch=FeatchType.LAZY)
@JoinColumn (name=
"Teacher_Student",
joinColumns = (
@JoinColumn (name=
"Teacher_ID", referencedColumnName=
"teacherid")),
inverseJoinColumns = (
@JoinColumn (name=
"Student_ID", referencedColumnName=
"Studentid")))
11.
@Transient : anotação de atributo que que indica que ela não está mapeada na tabela e deve ser ignorada.
12.
@Cache (usage=CacheConcurrencyStrategy.READ_WRITE) : anotação de classe que indica que para essa aplicação o objeto em questão usa cache.