【问题标题】:hibernate to update email as proper email with the firstname from database?休眠以使用数据库中的名字将电子邮件更新为正确的电子邮件?
【发布时间】:2021-04-17 12:37:39
【问题描述】:

我想将数据库中的电子邮件更新为正确的电子邮件,例如 abc.@gmial.com 为了做到这一点,我想从数据库中读取 firstName,但是当我编写以下语法时,它给了我错误

我的语法是使用休眠 session.createQuery。

Student myStudent=new Student();
                 
session.createQuery("update Student set email="+myStudent.getFirstName()+"'@gmail.com'").executeUpdate();

错误是 错误:第 1:65 行:意外令牌:'@gmail.com' 第 1:65 行:意外令牌:'@gmail.com' 在 org.hibernate.hql.internal.antlr.HqlBaseParser.concatenation(HqlBaseParser.java:760) 在 org.hibernate.hql.internal.antlr.HqlBaseParser.newValue(HqlBaseParser.java:615) 在 org.hibernate.hql.internal.antlr.HqlBaseParser.assignment(HqlBaseParser.java:569) 在 org.hibernate.hql.internal.antlr.HqlBaseParser.setClause(HqlBaseParser.java:498) 在 org.hibernate.hql.internal.antlr.HqlBaseParser.updateStatement(HqlBaseParser.java:248) 在 org.hibernate.hql.internal.antlr.HqlBaseParser.statement(HqlBaseParser.java:183) 在 org.hibernate.hql.internal.ast.QueryTranslatorImpl.parse(QueryTranslatorImpl.java:294) 在 org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:189) 在 org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:144) 在 org.hibernate.engine.query.spi.HQLQueryPlan.(HQLQueryPlan.java:113) 在 org.hibernate.engine.query.spi.HQLQueryPlan.(HQLQueryPlan.java:73) 在 org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:162) 在 org.hibernate.internal.AbstractSharedSessionContract.getQueryPlan(AbstractSharedSessionContract.java:604) 在 org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:716) 在 org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:113) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(未知来源) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(未知来源) 在 java.lang.reflect.Method.invoke(未知来源) 在 org.hibernate.context.internal.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:351) 在 com.sun.proxy.$Proxy30.createQuery(未知来源) 在 com.luv2code.hibernate.demo.UpdateStudentDemo.main(UpdateStudentDemo.java:53)

2021 年 1 月 12 日晚上 8:00:32 org.hibernate.engine.jdbc.connections.internal.DriverManagerConnectionProviderImpl$PoolState 停止 信息:HHH10001008:清理连接池 [jdbc:mysql://localhost:3306/hb_student_tracker?useSSL=false] 线程“主”java.lang.IllegalArgumentException 中的异常:org.hibernate.hql.internal.ast.QuerySyntaxException:意外令牌:'@gmail.com' 靠近第 1 行,第 65 列 [更新 com.luv2code.hibernate.demo.entity .学生设置 email=null'@gmail.com'] 在 org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:138) 在 org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:181) 在 org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:188) 在 org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:725) 在 org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:113) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(未知来源) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(未知来源) 在 java.lang.reflect.Method.invoke(未知来源) 在 org.hibernate.context.internal.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:351) 在 com.sun.proxy.$Proxy30.createQuery(未知来源) 在 com.luv2code.hibernate.demo.UpdateStudentDemo.main(UpdateStudentDemo.java:53) 引起:org.hibernate.hql.internal.ast.QuerySyntaxException:意外令牌:'@gmail.com' 靠近第 1 行,第 65 列 [更新 com.luv2code.hibernate.demo.entity.Student set email=null'@gmail .com'] 在 org.hibernate.hql.internal.ast.QuerySyntaxException.convert(QuerySyntaxException.java:74) 在 org.hibernate.hql.internal.ast.ErrorTracker.throwQueryException(ErrorTracker.java:93) 在 org.hibernate.hql.internal.ast.QueryTranslatorImpl.parse(QueryTranslatorImpl.java:301) 在 org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:189) 在 org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:144) 在 org.hibernate.engine.query.spi.HQLQueryPlan.(HQLQueryPlan.java:113) 在 org.hibernate.engine.query.spi.HQLQueryPlan.(HQLQueryPlan.java:73) 在 org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:162) 在 org.hibernate.internal.AbstractSharedSessionContract.getQueryPlan(AbstractSharedSessionContract.java:604) 在 org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:716) ... 8 更多

【问题讨论】:

    标签: hibernate


    【解决方案1】:

    HQL 类似于 SQL。如果您想更新所有学生的电子邮件,请使用以下内容:

    session.createQuery("update Student set email = concat(firstName,'@gmail.com')").executeUpdate();
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2012-06-22
      • 1970-01-01
      • 2014-10-12
      • 2015-05-06
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多