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.
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.
posta suas classes
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;
}
}
Preciso trazer a classe Funcionalidade de acordo com o id do grupo de modulos.java
abraços.
...
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.
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.