Script MySQL para EJBQL. [RESOLVIDO]

5 respostas
Alberto_Cerqueira

Bom Dia,

Alguém consegue converter esse script para query EJBQL???

SELECT * FROM tbl_funcionalidade
inner join tbl_erp_funcionalidade as erp
    on (erp.id = tbl_funcionalidade.codigo)
    where erp.id_modulo = 1

abraços.

5 Respostas

mauriciot.silva

posta suas classes

Alberto_Cerqueira

Funcionalidade.java

package com.dpcomp.webevolution.nfe.orm.cadastro;

import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.Table;

@Entity
@Table(name="TBL_FUNCIONALIDADE")
@Inheritance(strategy = InheritanceType.JOINED)
public class Funcionalidade implements Serializable {

	
	@Id
	@GeneratedValue(strategy = GenerationType.IDENTITY)
	private Long codigo;

	@Column(name="nome")
	private String nome;
	
	@Column(name="descricao")
	private String descricao;
	
	@Column(name="url")
	private String url;
	
	@Column(name="ordenacao")
	private int ordenacao;

	public String getNome() {
		return nome;
	}

	public void setNome(String nome) {
		this.nome = nome;
	}

	public String getUrl() {
		return url;
	}

	public void setUrl(String url) {
		this.url = url;
	}

	public Long getCodigo() {
		return codigo;
	}

	public String getDescricao() {
		return descricao;
	}

	public void setDescricao(String descricao) {
		this.descricao = descricao;
	}

	public int getOrdenacao() {
		return ordenacao;
	}

	public void setOrdenacao(int ordenacao) {
		this.ordenacao = ordenacao;
	}
	
	
}

ERPFuncionalidade.java

package com.wave.erp.orm.cadastro.acesso;

import java.io.Serializable;

import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.PrimaryKeyJoinColumn;
import javax.persistence.Table;

import com.dpcomp.webevolution.nfe.orm.cadastro.Funcionalidade;

@Entity(name="ERPFuncionalidade")
@Table(name="TBL_ERP_FUNCIONALIDADE")
@PrimaryKeyJoinColumn(name="ID")
public class ERPFuncionalidade extends Funcionalidade implements Serializable {
	
	@ManyToOne(fetch= FetchType.EAGER)
	@JoinColumn(name="id_modulo")
	public Modulo modulo;

	public Modulo getModulo() {
		return modulo;
	}

	public void setModulo(Modulo modulo) {
		this.modulo = modulo;
	}
}

Modulos.java

package com.wave.erp.orm.cadastro.acesso;

public enum Modulos {
	CADASTRO(1), FINANCEIRO(2), VENDAS(3), PRODUCAO(4), COMPRAS(5), ESTOQUE(6), RELATORIO(7);
	
	private final Integer codigo;
	
	private Modulos(Integer codigo){
		this.codigo = codigo;
	}
	
	public Integer getCodigo(){
		return this.codigo;
	}
	
}

Modulo.java

package com.wave.erp.orm.cadastro.acesso;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;


@Entity
@Table(name="TBL_ERP_MODULO")
public class Modulo implements java.io.Serializable {

	@Id
	@GeneratedValue(strategy = GenerationType.IDENTITY)
	private Long id;
	
	@Column(name="codigo")
	private Integer codigo;
	
	@Column(name="descricao")
	private String descricao;

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

	public Long getId() {
		return id;
	}

	public String getDescricao() {
		return descricao;
	}

	public void setDescricao(String descricao) {
		this.descricao = descricao;
	}

	public Integer getCodigo() {
		return codigo;
	}

	public void setCodigo(Integer codigo) {
		this.codigo = codigo;
	}

	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + ((codigo == null) ? 0 : codigo.hashCode());
		return result;
	}

	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		Modulo other = (Modulo) obj;
		if (codigo == null) {
			if (other.codigo != null)
				return false;
		} else if (!codigo.equals(other.codigo))
			return false;
		return true;
	}
	
	
	
	
}
Alberto_Cerqueira

Preciso trazer a classe Funcionalidade de acordo com o id do grupo de modulos.java

abraços.

Alberto_Cerqueira
...
public static final String BUSCAR_FUNCIONALIDADES = "from Funcionalidade f " +
			"inner join ERPFuncionalidade erpf on f.codigo = erpf.id ";//where erpf.id_modulo = ";
...
...
@Override
	public List<Funcionalidade> buscarFuncionalidadeByGrupo(Long idGrupo) {
		Query query = em.createQuery(ERPCadastroSQL.BUSCAR_FUNCIONALIDADES);
		//query.setParameter("cdEmpresa", CodEmpresaHolder.get());
		@SuppressWarnings("unchecked")
		List<Funcionalidade> funcionalidade = (List<Funcionalidade>) query.getResultList();
		return funcionalidade;
	}
...

poque não consigo construir a query com esse código acima???

abraços.

Alberto_Cerqueira

Para criar query com inner join, só usando o hql (que não podia ser usada na arquitetura do sistema), conseguir construir a pagina html usando as referencia do java mesmo, e logica com o json/jquery.

Abraços.

Criado 6 de julho de 2012
Ultima resposta 12 de set. de 2012
Respostas 5
Participantes 2