Querydsl - 线程“main”中的异常java.lang.IllegalArgumentException:没有给出

时间:2017-01-19 17:01:17

标签: java spring hibernate jpa querydsl

我正在使用Spring MVC,Thymeleaf,JPA(Hibernate)和Querydsl构建系统。当我测试所有内容时,我遇到了这个例外:

log4j:WARN No appenders could be found for logger (org.springframework.core.env.StandardEnvironment).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
Serviço nulo: false
[SER_USU] - Fazendo consulta...
[SER_USU] - Dao nulo: false

Exception in thread "main" java.lang.IllegalArgumentException: No sources given
    at com.querydsl.jpa.JPAQueryBase.serialize(JPAQueryBase.java:56)
    at com.querydsl.jpa.JPAQueryBase.serialize(JPAQueryBase.java:50)
    at com.querydsl.jpa.impl.AbstractJPAQuery.createQuery(AbstractJPAQuery.java:98)
    at com.querydsl.jpa.impl.AbstractJPAQuery.createQuery(AbstractJPAQuery.java:94)
    at com.querydsl.jpa.impl.AbstractJPAQuery.fetch(AbstractJPAQuery.java:201)
    at com.regra7.st.db.dao.Dao_Usuario.getPorID(Dao_Usuario.java:35)
    at com.regra7.st.servico.Ser_Usuario.cadastrar(Ser_Usuario.java:46)
    at com.regra7.st.testes.TesteDAO_001.<init>(TesteDAO_001.java:43)
    at com.regra7.st.testes.TesteDAO_001.main(TesteDAO_001.java:19)

不幸的是,这不是很具描述性,因此,我不知道该怎么做。我已经尝试了一切,但我没有找到解决方案。是的,这就是所有消息(堆栈跟踪)。以下是我正在使用的一些文件......

pom.xml (我可能有一些依赖错误,我不确切知道):

<project 
    xmlns="http://maven.apache.org/POM/4.0.0" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.regra7</groupId>
    <artifactId>Sistema_Teste_001</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>war</packaging>
    <build>
        <sourceDirectory>src</sourceDirectory>
        <plugins>

            <plugin>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <warSourceDirectory>WebContent</warSourceDirectory>
                    <failOnMissingWebXml>false</failOnMissingWebXml>
                </configuration>
            </plugin>

            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.3</version>
                <configuration>
                    <source>1.7</source>
                    <target>1.7</target>
                </configuration>
            </plugin>

            <!-- QUERYDSL -->
            <plugin>
                <groupId>com.mysema.maven</groupId>
                <artifactId>apt-maven-plugin</artifactId>
                <version>1.1.3</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>process</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>target/generated-sources/java</outputDirectory>
                            <processor>com.querydsl.apt.jpa.JPAAnnotationProcessor</processor>
                        </configuration>
                    </execution>
                </executions>
            </plugin>

        </plugins>
    </build>
    <dependencies>

        <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 -->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.5</version>
        </dependency>

        <!-- SPRING MVC -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>4.3.5.RELEASE</version>
        </dependency>

        <!-- SPRING CONTEXT (SPRING CORE - TRANSIENT) -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>4.3.5.RELEASE</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.springframework/spring-orm -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-orm</artifactId>
            <version>4.3.5.RELEASE</version>
        </dependency>

        <!-- POSTGRESQL DRIVER JDBC -->
        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>9.3-1102-jdbc41</version>
        </dependency>

        <!-- API SERVLET E JSP -->
        <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>3.1.0</version>
        </dependency>

        <!-- BEAN VALIDATION -->
        <!-- https://mvnrepository.com/artifact/javax.validation/validation-api -->
        <dependency>
            <groupId>javax.validation</groupId>
            <artifactId>validation-api</artifactId>
            <version>1.1.0.Final</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-core -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>5.2.6.Final</version>
        </dependency>

        <!-- IMPLEMENTAÇÃO BEAN VALIDATION (HIBERNATE) -->
        <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-validator -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator</artifactId>
            <version>5.3.4.Final</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.hibernate.javax.persistence/hibernate-jpa-2.1-api -->
        <dependency>
            <groupId>org.hibernate.javax.persistence</groupId>
            <artifactId>hibernate-jpa-2.1-api</artifactId>
            <version>1.0.0.Final</version>
        </dependency>

        <dependency>
            <groupId>javax.el</groupId>
            <artifactId>javax.el-api</artifactId>
            <version>2.2.4</version>
        </dependency>
        <dependency>
            <groupId>org.glassfish.web</groupId>
            <artifactId>javax.el</artifactId>
            <version>2.2.4</version>
        </dependency>

        <!-- THYMELEAF -->
        <!-- https://mvnrepository.com/artifact/org.thymeleaf/thymeleaf -->
        <dependency>
            <groupId>org.thymeleaf</groupId>
            <artifactId>thymeleaf</artifactId>
            <version>3.0.3.RELEASE</version>
        </dependency>

        <!-- THYMELEAF PARA O SPRING 4 -->
        <!-- https://mvnrepository.com/artifact/org.thymeleaf/thymeleaf-spring4 -->
        <dependency>
            <groupId>org.thymeleaf</groupId>
            <artifactId>thymeleaf-spring4</artifactId>
            <version>3.0.3.RELEASE</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/com.querydsl/querydsl-core -->
        <dependency>
            <groupId>com.querydsl</groupId>
            <artifactId>querydsl-core</artifactId>
            <version>4.1.4</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/com.querydsl/querydsl-jpa -->
        <dependency>
            <groupId>com.querydsl</groupId>
            <artifactId>querydsl-jpa</artifactId>
            <version>4.1.4</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/com.querydsl/querydsl-apt -->
        <dependency>
            <groupId>com.querydsl</groupId>
            <artifactId>querydsl-apt</artifactId>
            <version>4.1.4</version>
        </dependency>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.6.1</version>
        </dependency>

        <!-- C3P0 -->
        <!-- https://mvnrepository.com/artifact/com.mchange/c3p0 -->
        <dependency>
            <groupId>com.mchange</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.5.2</version>
        </dependency>

    </dependencies>
</project>

spring-config.xml(app-context.xml):

<?xml version="1.0" encoding="UTF-8" standalone="no"?>

<!-- ARQUIVO DE CONFIGURAÇÃO DE CONTEXTO DE APLICAÇÃO. -->
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:mvc="http://www.springframework.org/schema/mvc" 
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="
            http://www.springframework.org/schema/beans
            http://www.springframework.org/schema/beans/spring-beans.xsd
            http://www.springframework.org/schema/mvc
            http://www.springframework.org/schema/mvc/spring-mvc.xsd
            http://www.springframework.org/schema/context
            http://www.springframework.org/schema/context/spring-context.xsd ">

    <!-- Mapeamento de recursos (arquivos css, fontes, imagens, dentre outros). -->
    <!-- <mvc:resources mapping="/css/**" location="/WEB-INF/recursos/css/" /> -->
    <!-- <mvc:resources mapping="/imagens/**" location="/WEB-INF/recursos/imagens/" /> -->
    <!-- <mvc:resources mapping="/fontes/**" location="/WEB-INF/recursos/fontes/" /> -->
    <!-- <mvc:resources mapping="/fontes/**" location="/WEB-INF/recursos/javascript/" /> -->

    <!-- Possibilita o uso de anotações Spring Mvc. -->
    <mvc:annotation-driven />

    <!-- Alternativa a declarar PersistenceAnnotationBeanPostProcessor, 
    um processador de anotações que lê @PersistenceContext. -->
    <context:annotation-config />

    <!-- Define local para procura de componentes Spring (beans configurados 
        por anotações em classes). -->
    <context:component-scan base-package="com.regra7.st.controle" />
    <context:component-scan base-package="com.regra7.st.db.dao" />
    <context:component-scan base-package="com.regra7.st.servico" />
    <context:component-scan base-package="com.regra7.st.testes" />

    <!-- MINHA DEFINIÇÃO COM MEUS CONVERSORES CRIADOS -->
    <mvc:annotation-driven conversion-service="servicoConversao"/>

    <!-- PROPERTY EDITOR NÃO FUNCIONOU, MAS ISSO SIM! -->
    <bean id="servicoConversao" 
        class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
        <property name="converters">
            <set>
                <bean class="com.regra7.st.formularios.conversores.Cov_String_LocalDate"/>
                <bean class="com.regra7.st.formularios.conversores.Cov_LocalDate_String"/>
            </set>
        </property>
    </bean>

    <!-- Template Resolver para Template Engine. -->
    <!-- <bean id="templateResolver" class="org.thymeleaf.templateresolver.ServletContextTemplateResolver"> 
        <property name="prefix" value="/WEB-INF/templates/" /> <property name="suffix" 
        value=".html" /> <property name="templateMode" value="HTML5" /> </bean> -->

    <!-- SpringResourceTemplateResolver automatically integrates with Spring's 
        own -->
    <!-- resource resolution infrastructure, which is highly recommended. -->
    <bean id="templateResolver"
        class="org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver">
        <property name="prefix" value="/WEB-INF/templates/" />
        <property name="suffix" value=".html" />
        <!-- HTML is the default value, added here for the sake of clarity. -->
        <property name="templateMode" value="HTML" />
        <!-- Template cache is true by default. Set to false if you want -->
        <!-- templates to be automatically updated when modified. -->
        <property name="cacheable" value="true" />
    </bean>

    <!-- SpringTemplateEngine automatically applies SpringStandardDialect and -->
    <!-- enables Spring's own MessageSource message resolution mechanisms. -->
    <bean id="templateEngine" class="org.thymeleaf.spring4.SpringTemplateEngine">
        <property name="templateResolver" ref="templateResolver" />
        <!-- Enabling the SpringEL compiler with Spring 4.2.4 or newer can speed 
            up -->
        <!-- execution in most scenarios, but might be incompatible with specific -->
        <!-- cases when expressions in one template are reused across different 
            data -->
        <!-- ypes, so this flag is "false" by default for safer backwards -->
        <!-- compatibility. -->
        <property name="enableSpringELCompiler" value="true" />
    </bean>

    <!-- View resolver do Thymeleaf. -->
    <bean class="org.thymeleaf.spring4.view.ThymeleafViewResolver">
        <property name="templateEngine" ref="templateEngine" />
    </bean>

    <!-- DATA SOURCE - Implementação do C3p0 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
        <!-- Propriedades de conexão -->
        <property name = "driverClass" value="org.postgresql.Driver" />
        <property name = "jdbcUrl" value="jdbc:postgresql://localhost:5432/SistemaTeste" />
        <property name = "user" value="postgres" />
        <property name = "password" value="admin" />

        <!-- Propriedades C3p0 -->
        <property name = "initialPoolSize"  value="3" />
        <property name = "minPoolSize"      value="5" />
        <property name = "maxPoolSize"      value="20" />
        <property name = "maxIdleTime"      value="1800" /> <!-- 1800 = 30 min -->
        <property name = "maxStatements"    value="50" />
    </bean>

    <!-- Fábrica EntityManager -->
    <bean id="emf"
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="persistenceUnitName" value="SistemaTeste" />
        <property name="dataSource" ref="dataSource" />
        <property name="jpaDialect">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect" />
        </property>
        <property name="jpaProperties">
            <props>
                <prop key="hibernate.hbm2ddl.auto">none</prop>
                <prop key="hibernate.dialect">org.hibernate.dialect.PostgreSQL82Dialect</prop>
                <prop key="hibernate.show_sql">false</prop>
                <prop key="hibernate.format_sql">false</prop>
                <prop key="hibernate.generate_statistics">false</prop>
                <prop key="hibernate.use_sql_comments">false</prop>
                <prop key="hibernate.default_schema">regrast</prop>
                <prop key="hibernate.jdbc.batch_size">50</prop>
            </props>
        </property>
    </bean>

    <!-- Gerenciador de transações PlatformTransactionManager -->
    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="emf" />
    </bean>

    <!-- INTERCEPTADORES -->
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/usuario/*" />
            <bean class="com.regra7.st.interceptadores.Login" />
        </mvc:interceptor>
    </mvc:interceptors>

</beans>

的persistence.xml:

<?xml version="1.0" encoding="UTF-8"?>
<persistence 
    xmlns="http://java.sun.com/xml/ns/persistence"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
    version="1.0">

    <persistence-unit name="SistemaTeste" transaction-type="RESOURCE_LOCAL">

        <!-- PROVEDOR JPA -->
        <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>

    </persistence-unit>

</persistence>

我的主要测试类

public class TesteDAO_001 
{
    public static void main(String[] args) 
    {
        new TesteDAO_001(); // Line 19
    }

    public TesteDAO_001()
    {
        AbstractApplicationContext ac = new ClassPathXmlApplicationContext("/META-INF/spring-config.xml");
        Ser_Usuario servico = ac.getBean(Ser_Usuario.class); // Service class

        // For_Cadastro is an account registration form.
        For_Cadastro form = new For_Cadastro();
        form.setNome("Maria Pereira Maxwell"); // Name
        form.setLogin("rodrigologinsoares001");
        form.setSenha1("minhasenha001001"); // Password
        form.setSenha2("minhasenha001001"); // Password confirmation
        form.setCpf("01234567890"); // CPF = Brazil's Social ID
        form.setNascimento(LocalDate.now()); // Birthday
        form.setPai(0L); // Father
        form.setMae(0L); // Mother
        form.setGenero(0L); // Gender

        System.out.printf("Serviço nulo: %s%n" , servico == null);
        servico.cadastrar(form); // Line 43

        ac.close();
    }
}

服务方法

@Autowired
private Dao_Usuario _daoUsu;

@Transactional(rollbackFor = Exception.class)
public void cadastrar(For_Cadastro form)
{
    imprimir("Fazendo consulta...");
    imprimir(String.format("Dao nulo: %s%n", this._daoUsu == null));

    // This may return null.    
    Usuario pai = this._daoUsu.getPorID(form.getPai()); // Line 46
    Usuario mae = this._daoUsu.getPorID(form.getMae());

    imprimir(String.format("pai nulo: %s%n", pai == null));
    imprimir(String.format("mea nulo: %s%n", mae == null));

    // Usuario is a Domain Model Object. A POJO representation of a table.
    Usuario usu = new Usuario(form.getCpf()); // CPF = Brazil's Social ID
    usu.setGenero(Genero.getGenero(form.getGenero())); // Gender
    usu.setNome(form.getNome()); // Name
    usu.setLogin(form.getLogin());
    usu.setSenha(form.getSenha1().getBytes()); // Password
    usu.setNascimento(form.getNascimento()); // Birthday
    usu.setMae(mae); // Mother
    usu.setPai(pai); // Father

    imprimir("Modelo criado. Salvando...");
    this._daoUsu.salvarAtualizar(usu); // Save/Update
    imprimir("Persistência concluída.");
}

DAO方法:

@PersistenceContext
protected EntityManager _em;

@Override
public Usuario getPorID(Long id) 
{   
    if(id == null)
    {
        return null;
    }

    return new JPAQueryFactory(this._em)
            .select(QUsuario.usuario)
            .where(QUsuario.usuario.id.eq(id))
            .fetchOne(); // Line 32
}

我正在学习如何使用Querydsl。如果您需要我在这里添加更多代码,请说明。我已经研究了谷歌,也在社区。不幸的是我没有发现任何相关信息。拜托,有人可以帮助我吗?

感谢您的时间和耐心。

修改

这是我的 Domain Model Usuario 类:

@Entity
@Table(name="tb_usuarios")
public class Usuario
{
    @Id
    @SequenceGenerator(
            name="ger_id_usuario" , 
            sequenceName="tb_usuarios_id_seq" , 
            allocationSize=1 , 
            initialValue = 1)
    @GeneratedValue(
            strategy=GenerationType.SEQUENCE , 
            generator="ger_id_usuario")
    @Column(
            name = "usu_id" , 
            unique = true)
    protected Long id;

    // Name
    @Column(name = "usu_nome" , unique = true)
    protected String nome;

    // "Business Key"
    @Column(name = "usu_login" , unique = true)
    protected String login;

    // Password
    @Column(name = "usu_senha" , unique = true)
    protected byte[] senha;

    // Brazil's Social ID
    // "Business Key"
    @Column(name = "usu_cpf" , unique = true)
    protected String cpf;

    // Registration moment (date and time)
    @Column(name = "usu_nascimento")
    protected Date nascimento;

    // Gender
    @Column(name = "usu_genero")
    protected byte genero;

    // Father of this person (it may be null).
    @ManyToOne(fetch = FetchType.LAZY , cascade=CascadeType.ALL)
    @JoinColumn(name = "usu_pai")
    protected Usuario pai;

    // Mother of this person (it may be null).
    @ManyToOne(fetch = FetchType.LAZY , cascade=CascadeType.ALL)
    @JoinColumn(name = "usu_mae")
    protected Usuario mae;

    @Column(name = "usu_cadastro")
    protected Timestamp cadastro;

    // Children as a father.
    @OneToMany(mappedBy="pai" , fetch = FetchType.LAZY , cascade = CascadeType.ALL)
    protected Set<Usuario> filhosComoPai;

    // Children as a mother.
    @OneToMany(mappedBy="mae" , fetch = FetchType.LAZY , cascade = CascadeType.ALL)
    protected Set<Usuario> filhosComoMae;

    // Required by default by JPA, public or protected constructor, with no arguments.
    protected Usuario()
    {
        this.filhosComoPai = new HashSet<>();
        this.filhosComoMae = new HashSet<>();
    }

    /** For anyone who works with this class, it must provide a CPF, guaranteeing uniqueness, thus preventing this class from suffering problems when it is inside collections. */
    public Usuario(String cpf)
    {
        if(Util_Validador.isCPFValido(cpf) == false)
        {
            throw new IllegalArgumentException("CPF não encontra-se válido.");
        }

        this.cpf = cpf;

        this.filhosComoPai = new HashSet<>();
        this.filhosComoMae = new HashSet<>();
    }

    // Name
    public void setNome(String nome)
    {
        if(Util_Validador.isNomeValido(nome, 8) == false)
        {
            throw new IllegalArgumentException("Nome de pessoa não encontra-se válido.");
        }

        this.nome = nome;
    }

    public void setLogin(String login)
    {
        if(Util_Validador.isLoginValido(login, 8) == false)
        {
            throw new IllegalArgumentException("Login não encontra-se válido.");
        }

        this.login = login;
    }

    // Password
    public void setSenha(byte[] senha)
    {
        this.senha = senha;
    }

    // Birthday
    public void setNascimento(LocalDate nascimento)
    {
        this.nascimento = Date.valueOf(nascimento);
    }

    // Gender
    public void setGenero(Genero genero)
    {
        if(genero == null)
        {
            throw new NullPointerException("O gênero passado como argumento encontra-se nulo.");
        }

        this.genero = genero.getID();
    }

    /** Defines a father for this person (child).*/
    public void setPai(Usuario pai)
    {
        // It is already?
        if( this.pai == null ||
            this.pai.equals(pai) == false)
        {
            // Remove previous father from this child.
            if(this.pai != null)
            {
                this.pai.removeFilho(this);
            }

            // Defines the new father for this child.
            // There may be a null assignment here!
            this.pai = pai;

            // Add this child to a new parent.
            if(pai != null)
            {
                if(pai.getFilhos().contains(this) == false)
                {
                    pai.addFilho(this);
                }
            }
        }
    }

    // Same logic.
    public void setMae(Usuario mae)
    {
        if( this.mae == null ||
            this.mae.equals(mae) == false)
        {
            if(this.mae != null)
            {
                this.mae.removeFilho(this);
            }

            this.mae = mae;

            if(mae != null)
            {
                if(mae.getFilhos().contains(this) == false)
                {
                    mae.addFilho(this);
                }
            }
        }
    }

    public Long getID()
    {
        return this.id;
    }

    // Name
    public String getNome()
    {
        return this.nome;
    }

    public String getLogin()
    {
        return this.login;
    }

    // Password
    public byte[] getSenha()
    {
        return this.senha;
    }

    // CPF = Brazil's Social ID
    public String getCPF()
    {
        return this.cpf;
    }

    // Birthday
    public LocalDate getNascimento()
    {
        return this.nascimento.toLocalDate();
    }

    // Gender
    public Genero getGenero()
    {
        return Genero.getGenero(
                Long.getLong(
                        Byte.toString(this.genero)));
    }

    // Father
    public Usuario getPai()
    {
        return this.pai;
    }

    // Mother
    public Usuario getMae()
    {
        return this.mae;
    }

    // Date and time of registration (produced by database after insertion).
    public LocalDateTime getCadastro()
    {
        return this.cadastro.toLocalDateTime();
    }

    // Children of this person
    public Set<Usuario> getFilhos()
    {
        // "Genero" is a enum type (Gender), with MALE ("HOMEM") and FEMALE ("MULHER").
        if(this.getGenero() == Genero.HOMEM)
        {
            return Collections.unmodifiableSet(this.filhosComoPai);
        }

        return Collections.unmodifiableSet(this.filhosComoMae);
    }

    // Add a child ("filho") to this person.
    public boolean addFilho(Usuario filho)
    {
        this.isUsuarioNula(filho);
        boolean add = false;

        // FATHER
        if(this.getGenero() == Genero.HOMEM)
        {
            add = this.filhosComoPai.add(filho);

            if(add)
            {
                if( filho.getPai() == null || 
                    filho.getPai().equals(this) == false)
                {
                    Usuario paiAnterior = filho.getPai();

                    if(paiAnterior != null)
                    {
                        paiAnterior.removeFilho(filho);
                    }

                    filho.setPai(this);
                }
            }
        }
        // MOTHER
        else
        {
            add = this.filhosComoMae.add(filho);

            if(add)
            {
                if( filho.getMae() == null ||
                    filho.getMae().equals(this) == false)
                {
                    Usuario maeAnterior = filho.getMae();

                    if(maeAnterior != null)
                    {
                        maeAnterior.removeFilho(filho);
                    }

                    filho.setMae(this);
                }
            }
        }

        return add;
    }

    // Removes the child ("filho") from this person.
    public boolean removeFilho(Usuario filho)
    {
        this.isUsuarioNula(filho);
        boolean rem = false;

        // FATHER
        if(this.getGenero() == Genero.HOMEM)
        {
            rem = this.filhosComoPai.remove(filho);

            if(rem)
            {
                if( filho.getPai() == null ||
                    filho.getPai().equals(this) == false)
                {
                    filho.setPai(null);
                }
            }
        }
        // MOTHER
        else
        {
            rem = this.filhosComoMae.remove(filho);

            if(rem)
            {
                if( filho.getMae() == null ||
                    filho.getMae().equals(this) == false)
                {
                    filho.setMae(null);
                }
            }
        }

        return rem;
    }

    // Just to print the same message.
    private void isUsuarioNula(Usuario p)
    {
        if(p == null)
        {
            throw new IllegalArgumentException("Usuario passada em argumento encontra-se nula.");
        }
    }

    @Override
    public boolean equals(Object o)
    {
        if (o == null) 
        {
            return false;
        }
        else if (o == this) 
        {
            return true;
        }
        else if (o.getClass() != this.getClass()) 
        {
            return false;
        }

        Usuario c = (Usuario) o;

        // This ensures consistent data work, and prevents something from happening silently, without us knowing why it happened.
        if(c.getCPF() == null || c.getCPF().length() <= 0)
        {
            throw new IllegalStateException("Valor de CPF inexistente. Uma comparação não é possível.");
        }

        return c.getCPF().equals(this.getCPF());
    }

    @Override
    public int hashCode()
    {
        // I'm using Apacho Commons Lang.
        return new HashCodeBuilder()
                .append(this.getCPF()).toHashCode();
    }
}

数据库已经创建。我正在我的个人电脑上测试它。

编辑2

我想分享我的项目。不幸的是我不知道如何使用Github,我的帖子有近30k字符,所以我上传了我的项目(用Eclipse Mars 2制作)作为war文件。以下是链接:

http://www.megafileupload.com/8hon/Sistema_Teste_001.war(点击免费用户下载下载war文件)

mirror(点击下载此文件下载)

为了提供帮助,每个包都包含一个名为“package-info”的文件。如果您有任何疑问,请查看此文件。除此之外,还增加了英文评论以供澄清。

我很抱歉。我知道以这种方式下载我的项目并不是很方便,但这是我当时发现的唯一解决方案。这样你就可以完全看到我的项目。

回答你的问题,我正在以正常的方式测试这段代码,作为一个可执行的Java程序。正在生成Q类,我的IDE没有指责任何语法错误或任何东西。我正确点击我的项目并选择“Run As ...” - &gt; “3 Java Application”运行。要生成我的Q类,我点击“Run As ...” - &gt; “8 Maven生成源”。

2 个答案:

答案 0 :(得分:4)

我很尴尬地说我没有早点赶上这个。您的查询语法实际上是错误的

return new JPAQueryFactory(this._em)
        .select(QUsuario.usuario)
        .where(QUsuario.usuario.id.eq(id))
        .fetchOne();  

应该是

 return new JPAQueryFactory(this._em)
        .selectFrom(QUsuario.usuario)
        .where(QUsuario.usuario.id.eq(id))
        .fetchOne(); 

selectFrom 而不是select。

答案 1 :(得分:0)

我怀疑生成的源不在Eclipse项目的构建路径上。因此,当您运行Java应用程序时,它无法找到Q源文件/类。右键单击Eclipse Mars项目,然后选择“属性”选项。确保您位于“源”选项卡上并单击“添加文件夹”并选择目标/ generated-sources / java文件夹,然后单击“确定”。这会将生成的源添加到Eclipse Mars项目中。然后尝试运行Java主类。