草庐IT

query_statement

全部标签

java - hibernate 中的createSQLQuery使用Prepared Statement?

我在Hibernate中使用createSQLQuery和setString(无硬编码值)。我想知道Hibernate是否将PreparedStatement用于createSQLQuery?关注:我想在缓存中保留此查询创建的执行计划,以便下次在数据库上触发相同的查询时,它将使用相同的执行计划。仅供引用:我使用的是MSSQLServer2008/*ThisisjustexampleI'mnotusingsamequery*/QuerynativeSQLQuery=session.createSQLQuery("selectFirstnamefromuser_masterwhereuse

java - 每个子类继承关系表 : How to query against the Parent class without loading any subclass ? ?? ( hibernate )

假设一个每个子类继承关系的表可以在下面描述(来自wikibooks.org-参见here)注意父类不是抽象的@Entity@Inheritance(strategy=InheritanceType.JOINED)publicclassProject{@Idprivatelongid;//Otherproperties}@Entity@Table(name="LARGEPROJECT")publicclassLargeProjectextendsProject{privateBigDecimalbudget;}@Entity@Table(name="SMALLPROJECT")publi

java - Spring 数据 : is it possible to have subqueries in the Query annotation?

我想知道是否可以在@Query注释中包含子查询(org.springframework.data.jpa.repository.Query;)我在第一个子查询括号中收到QuerySyntaxException。这是我的问题@Query(value="selectc1fromComplaintModelc1,"+"(selectc2.id,min(cb.termDate)minDatefromComplaintModelc2"+"joinc2.complaintBulletscbjoincb.statusswheres.code=?1"+"groupbyc2.id)tmpwherec1.

java - Spring NamedParameterJDBCTemplate 重用Prepared Statements

我正在使用SpringNamedParameterJdbcTemplate从表中获取一些值。出于某种原因,与在SQLManagementStudio上运行相同的查询相比,查询在我的Java应用程序中运行得非常慢。我还在探查器中注意到,准备好的语句不会被重用。如果我在我的JAVA应用程序中多次运行相同的查询,我会看到正在执行不同的准备好的语句。所以,不确定为什么这些语句没有被重用。性能变慢是因为我在查询中使用了IN子句吗?这是我的示例java代码StringBuildervQuery=newStringBuilder();vQuery.append("SELECTSUM(Qty)FROM

java - 在 Java 中完全切换枚举会产生 "Missing return statement"错误

假设,我们有switch语句,它完全涵盖了枚举参数的所有可能情况,并且也有null检查,不会因为"Missingreturnstatement"而被编译。enumFoo{ONE,TWO}intfooToInt(Foofoo){if(foo==null){thrownewNullPointerException();}switch(foo){caseONE:return1;caseTWO:return2;}}我知道,从default案例或枚举之后抛出异常,或者访问枚举元素而不是switch将解决问题。但我不明白这种行为的技术原因:显然,没有可能的执行分支不会导致return或throw。

java - Hibernate Criteria Query - 嵌套条件

我不知道如何使用HibernateCriteriasynthax创建这样的查询select*fromxwherex.a='abc'and(x.b='def'orx.b='ghi')你知道怎么做吗?我正在使用HibernateRestriction静态方法,但我不明白如何指定嵌套的“或”条件 最佳答案 您的具体查询可以是:crit.add(Restrictions.eq("a","abc"));crit.add(Restrictions.in("b",newString[]{"def","ghi"});如果您想了解一般的AND和OR,

java - JPQL 检查大于小于今天@Query 注解中的日期

我想使用JPQL检查天气validTill日期是否大于today。我知道我可以通过跟随来实现这一目标。Queryq=em.createQuery("selectefromMyEntityewheree.validTill>:today");并传递:today参数。但这不是我想要的。我想在Spring中使用CrudRepository中的@Query注释来做到这一点。这是我在CrudRepository中的代码段@Query("SELECTeFROMMyEntityeWHEREe.validFromfindAllValid();我不知道应该在TODAY位置放什么来获取今天的日期。请帮助我

Java XPath : Queries with default namespace xmlns

我想对此文件执行XPath查询(显示摘录):这是我正在使用的代码片段:DocumentBuilderFactorydomFactory=DocumentBuilderFactory.newInstance();DocumentBuilderbuilder=domFactory.newDocumentBuilder();Documentdocument=builder.parse(newFile(testFile));XPathFactoryfactory=XPathFactory.newInstance();XPathxpath=factory.newXPath();xpath.set

Java 问题 : Is it possible to have a switch statement within another one?

我有一个是或否的问题和答案。我想再问一个是或否的问题,如果是的话。我的导师希望我们使用charAt(0)作为答案的输入。是否可以在另一个语句中使用switch语句(如嵌套的if语句)?编辑:这是我的伪代码示例=display"Wouldyouliketoaddalink(y=yesorn=no)?"inputaddLinkswitch(link)case'y':display"Wouldyouliketopay3monthsinadvance"+"(y=yesorn=no)?"inputadvancePayswitch(advPay)case'y':linkCost=0.10*(3*1

java - query.list 和 query.iterate 的区别

使用Query.list()到底有什么区别?和Query.iterator()?使用其中任何一个是否有任何性能增强。我的意思是他们中的任何一个都在实现lazyloading?或者是Query.iterator()最终与query.list().iterate()相同还有为什么没有Criteria.iterator()只有Criteria.list() 最佳答案 Query.list():执行1个SQL查询并加载整个数据。即使记录存在于缓存中,也会执行新的SQL查询以从数据库加载记录。Listlist1=session.createQ