Hello,
In the reference manual, it is stated that the following snippet should work:
QSurvey survey = QSurvey.survey;
SQLQueryFactory queryFactory = new SQLQueryFactory(configuration, dataSource);
queryFactory.insert(survey)
.columns(survey.id, survey.name)
.values(3, "Hello").execute(); That is, insert needs a parameter of type
RelationalPath. However, the generated query types (e.g.
QSurvey) does not implement
RelationalPath, but
EntityPathBase. Hence,
insert() statement fails to compile. What might I be missing?
Best.
Used pom.xml is as follows:
<properties>
<javax.persistence.api.version>2.1.0</javax.persistence.api.version>
<querydsl.version>4.0.2</querydsl.version>
<slf4j.log4j12.version>1.6.1</slf4j.log4j12.version>
<slf4j.api.version>1.7.12</slf4j.api.version>
</properties>
<dependencies>
<dependency>
<groupId>org.eclipse.persistence</groupId>
<artifactId>javax.persistence</artifactId>
<version>${javax.persistence.api.version}</version>
</dependency>
<dependency>
<groupId>com.querydsl</groupId>
<artifactId>querydsl-sql</artifactId>
<version>${querydsl.version}</version>
</dependency>
<dependency>
<groupId>com.querydsl</groupId>
<artifactId>querydsl-apt</artifactId>
<version>${querydsl.version}</version>
</dependency>
<dependency>
<groupId>org.hsqldb</groupId>
<artifactId>hsqldb</artifactId>
<version>2.3.3</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.api.version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${slf4j.log4j12.version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<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>