`
linwei_211
  • 浏览: 192354 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

hibernate在DB2数据库上使用报DB2 SQL error: SQLCODE: -104, SQLSTATE: 42601的解决

阅读更多

     前一段时间在做一个项目时,遇到同样的代码在连接oracle的时候正常,在连接DB2数据库的时候出现异常不说,后台哗哗的报错.......直接上图吧:
[myProject] ERROR 2012-08-08 17:41:31,921 method:org.hibernate.util.JDBCExceptionReporter.logExceptions(JDBCExceptionReporter.java:72)
DB2 SQL error: SQLCODE: -104, SQLSTATE: 42601, SQLERRMC: );(+;(
[myProject] WARN 2012-08-08 17:41:31,921 method:org.hibernate.util.JDBCExceptionReporter.logExceptions(JDBCExceptionReporter.java:71)
SQL Error: -727, SQLState: 56098
[myProject] ERROR 2012-08-08 17:41:31,921 method:org.hibernate.util.JDBCExceptionReporter.logExceptions(JDBCExceptionReporter.java:72)
DB2 SQL error: SQLCODE: -727, SQLSTATE: 56098, SQLERRMC: 2;-104;42601;)|(+|(
[myProject] WARN 2012-08-08 17:41:31,921 method:org.hibernate.util.JDBCExceptionReporter.logExceptions(JDBCExceptionReporter.java:71)
SQL Error: -727, SQLState: 56098
[myProject] ERROR 2012-08-08 17:41:31,921 method:org.hibernate.util.JDBCExceptionReporter.logExceptions(JDBCExceptionReporter.java:72)
DB2 SQL error: SQLCODE: -727, SQLSTATE: 56098, SQLERRMC: 2;-104;42601;)|(+|(
org.hibernate.exception.GenericJDBCException: could not load an entity: [cn.test.oais.driver.database.EssTag#23111]
 at org.hibernate.exception.ErrorCodeConverter.handledNonSpecificException(ErrorCodeConverter.java:92)
 at org.hibernate.exception.ErrorCodeConverter.convert(ErrorCodeConverter.java:80)
 at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
 at org.hibernate.loader.Loader.loadEntity(Loader.java:1359)
 at org.hibernate.loader.entity.EntityLoader.load(EntityLoader.java:116)
 at org.hibernate.loader.entity.EntityLoader.load(EntityLoader.java:101)
 at org.hibernate.loader.entity.BatchingEntityLoader.load(BatchingEntityLoader.java:82)
 at org.hibernate.persister.entity.BasicEntityPersister.load(BasicEntityPersister.java:2471)
 at org.hibernate.event.def.DefaultLoadEventListener.loadFromDatasource(DefaultLoadEventListener.java:351)
 at org.hibernate.event.def.DefaultLoadEventListener.doLoad(DefaultLoadEventListener.java:332)
 at org.hibernate.event.def.DefaultLoadEventListener.load(DefaultLoadEventListener.java:113)
 at org.hibernate.event.def.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:151)[
 at org.hibernate.event.def.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:79)
 at org.hibernate.impl.SessionImpl.load(SessionImpl.java:603)
 at org.hibernate.impl.SessionImpl.load(SessionImpl.java:596)
 at cn.keyoflov.oais.driver._BaseRootDAO.load(_BaseRootDAO.java:744)
 at cn.test.oais.driver.database.impl.StructureDefineService.getEssTag(StructureDefineService.java:1288)
 at cn.test.oais.driver.database.impl.StructureDefineService.setTag(StructureDefineService.java:1644)
 at cn.test.oais.ipe.metadata.Tag.setTag(Tag.java:163)
 at cn.test.oais.webapp.action.manage.metadata.StructureAction.editTags(StructureAction.java:4257)
 at cn.test.oais.webapp.action.manage.metadata.StructureAction.saveGridData(StructureAction.java:4585)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
 at java.lang.reflect.Method.invoke(Method.java:585)
 at org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:276)
 at cn.test.oais.webapp.struts.BaseAction._execute(BaseAction.java:181)
 at cn.test.oais.webapp.struts.BaseAction.execute(BaseAction.java:155)
 at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:421)
 at cn.test.oais.webapp.struts.RequestDynamicProcessor.process(RequestDynamicProcessor.java:114)
 at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1164)
 at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:415)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at cn.test.oais.webapp.filter.ActionFilter.doFilter(ActionFilter.java:88)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at org.tuckey.web.filters.urlrewrite.UrlRewriteFilter.doFilter(UrlRewriteFilter.java:323)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at cn.test.oais.webapp.filter.GZIPFilter.doFilter(GZIPFilter.java:49)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at org.displaytag.filter.ResponseOverrideFilter.doFilter(ResponseOverrideFilter.java:125)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:75)
 at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at com.opensymphony.clickstream.ClickstreamFilter.doFilter(ClickstreamFilter.java:42)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:174)
 at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:292)
 at org.acegisecurity.intercept.web.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:108)
 at org.acegisecurity.intercept.web.SecurityEnforcementFilter.doFilter(SecurityEnforcementFilter.java:197)
 at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:303)
 at org.acegisecurity.providers.anonymous.AnonymousProcessingFilter.doFilter(AnonymousProcessingFilter.java:143)
 at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:303)
 at org.acegisecurity.ui.rememberme.RememberMeProcessingFilter.doFilter(RememberMeProcessingFilter.java:154)
 at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:303)
 at org.acegisecurity.wrapper.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:50)
 at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:303)
 at org.acegisecurity.ui.AbstractProcessingFilter.doFilter(AbstractProcessingFilter.java:246)
 at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:303)
 at org.acegisecurity.context.HttpSessionContextIntegrationFilter.doFilter(HttpSessionContextIntegrationFilter.java:220)
 at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:303)
 at org.acegisecurity.util.FilterChainProxy.doFilter(FilterChainProxy.java:173)
 at org.acegisecurity.util.FilterToBeanProxy.doFilter(FilterToBeanProxy.java:120)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at cn.test.oais.webapp.filter.SessionTimeoutFilter.doFilter(SessionTimeoutFilter.java:45)
 at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
 at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
 at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
 at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
 at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
 at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
 at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
 at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
 at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
 at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
 at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
 at java.lang.Thread.run(Thread.java:595)
Caused by: com.ibm.db2.jcc.c.SqlException: DB2 SQL error: SQLCODE: -104, SQLSTATE: 42601, SQLERRMC: );(+;(
 at com.ibm.db2.jcc.c.tf.e(tf.java:1680)
 at com.ibm.db2.jcc.c.tf.a(tf.java:1239)
 at com.ibm.db2.jcc.b.jb.h(jb.java:139)
 at com.ibm.db2.jcc.b.jb.a(jb.java:43)
 at com.ibm.db2.jcc.b.w.a(w.java:30)
 at com.ibm.db2.jcc.b.cc.f(cc.java:161)
 at com.ibm.db2.jcc.c.tf.n(tf.java:1219)
 at com.ibm.db2.jcc.c.uf.gb(uf.java:1816)
 at com.ibm.db2.jcc.c.uf.d(uf.java:2298)
 at com.ibm.db2.jcc.c.uf.X(uf.java:508)
 at com.ibm.db2.jcc.c.uf.executeQuery(uf.java:491)
 at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeQuery(NewProxyPreparedStatement.java:76)
 at org.hibernate.jdbc.AbstractBatcher.getResultSet(AbstractBatcher.java:120)
 at org.hibernate.loader.Loader.getResultSet(Loader.java:1272)
 at org.hibernate.loader.Loader.doQuery(Loader.java:391)
 at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:218)
 at org.hibernate.loader.Loader.loadEntity(Loader.java:1345)
 ... 86 more


查看报错的方法,发现里面代码是
 private EssTag getEssTag(EssStructure es, Field identifier, Session session)
   throws Exception {
  return (EssTag)
this.load(EssTag.class, this.getTagId(es, identifier,session), session);
 }
 
而报错的代码就是this.load(EssTag.class, this.getTagId(es, identifier,session), session)这一句.....
 
然后看一下我从网上查到的关于这个异常的解释
 org.hibernate.exception.GenericJDBCException: could not load an entity
 
(解释一下this.getTagId(es, identifier,session)取出来的就是一个long数据,值为23111。)
 有说是:
 1.普遍的人都会想到的,也就是大多数说的比较浅显的就是说
没有主键=23111的这条记录
于是找到EssTag.hbm.xml,找到其映射表名ess_tag,在PL/SQL
 下select * from ess_tag where id=23111 ,确实存在这个记录,这个因素可以排除。

 2.有说是JDBC驱动的问题,问题是驱动包版本过低,说换一个jar包问题迎刃而解,我不信,但还是查看了jar包版本,发现是最新的jar包。当然这其中也有说是hibernate的jar包的问题的,我更不信,况且如果是jar包的问题的话,
 oracle10G下可以正常跑程序啊,到了DB2数据库hibernate的jar包就不好使了,这个理由太扯了......

 

下面关注这个异常
Caused by: com.ibm.db2.jcc.c.SqlException: DB2 SQL error: SQLCODE: -104, SQLSTATE: 42601, SQLERRMC: );(+;(
参照http://www.ufaith.cn/read-65.html这个博客里面的关于DB2各代码的解释,不难看出是说sql有问题.....那么我就奇怪了,这明明就是利用hibernate的机制,直接load数据,传一个实体xx.class,数据主键id,session,就可以加载该条数据
(注意:前提是存在这个实体xx的映射文件,而且xx的映射文件一定要被装载,
在我的项目中是有EssTag.java,有EssTag.hbm.xml,而且applicationContext-resources.xml里面已经装载了映射文件。)

不过我还是比较相信确实sql有问题,于是在spring配置文件applicationContext-resources.xml里面将
              <!-- 输出所有SQL语句到控制台.取值 true | false  -->
             
<prop key="hibernate.show_sql">false</prop>
这一项的值改为true,于是所有的hql全都打印在控制台了,翻译成sql之后,把sql语句粘到oracle 的PL/SQL窗口可以顺利执行,粘到DB2的sql执行窗口,果然执行不了..........

     读者请理解一下这里.....我就不将我的真实sql粘过来了.........


     可以告诉大家的是,那个sql是很长的,使用的外连接,就是那种很传统的外连接写法,使用“(+)”来表示的那种,之前有听过说8i以下的版本不支持使用LEFT/RIGHT/FULL OUTER JOIN这种的外连接写法,因为使LEFT/RIGHT/FULL OUTER JOIN这种的外连接写法是比较高级的语法,而8i以下版本过低,解析不了这么高级的语法.......当然这是题外话,目的是想说这个sql在目前的oracle中(无论版本高低)是完全不可能出问题的......

 

     注意到这个报错信息SQLERRMC: );(+;(,注意到那几个奇怪的括号,于是我也是猜想,这个sql里面就外连接那里出现(+),难道是这个外连接导致的......于是把(+)这种的外连接翻译成LEFT OUTER JOIN 的这种写法,放到DB2中去执行,可以顺利执行......

 

     于是真相渐渐渐渐浮出水面,答案越来越清晰了.......

 

      DB2数据库不支持(+)这种的外连接的写法,支持LEFT OUTER JOIN 这种的外连接写法,但目前我还不太确信是不是所有DB2版本都不支持,我所知道的是8.x和9.X的版本目前都不支持(+)这种的外连接写法.......


读者不防自己尝试一下:
1. LEFT OUTER JOIN:左外关联
SELECT e.last_name, e.department_id, d.department_name
FROM employees e
LEFT OUTER JOIN departments d
ON (e.department_id = d.department_id);
(这种语法在DB2下能执行成功)

 

等价于
SELECT e.last_name, e.department_id, d.department_name
FROM employees e, departments d
WHERE e.department_id=d.department_id(+);
(这种语法在DB2下不能执行成功)

 

结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录。

 

2. RIGHT OUTER JOIN:右外关联
SELECT e.last_name, e.department_id, d.department_name
FROM employees e
RIGHT OUTER JOIN departments d
ON (e.department_id = d.department_id);
(这种语法在DB2下能执行成功)

 

等价于
SELECT e.last_name, e.department_id, d.department_name
FROM employees e, departments d
WHERE e.department_id(+)=d.department_id;

(这种语法在DB2下不能执行成功)

 

结果为:所有员工及对应部门的记录,包括没有任何员工的部门记录。


      但是又出现了一个比较纠结的问题,代码里面用的是hibernate的load...直接传的xx.class,id,session,那一堆hql是它自己内部拼出来的啊,我怎么样去改变它拼hql的语法啊,苦恼啊 ,苦恼....无尽的痛苦.......我遇到问题总是会自己先纠结上一阵的,自己能办到的事,坚决不求别人.....无奈之下,请教了一个DB2数据库高手吧.......

     我把我的研究成果告诉了他,他也确认了确实是外连接语法不正确导致的,他告诉我一个配置文件里面可以配置DB2外连接的语法,是使用left outer join ,还是(+).....
但是他也不记得在哪个配置文件里面配置的了............
于是我又开始苦恼啊 ,苦恼...................................................................................


      后来我发现是在applicationContext-resources.xml里面有个
<prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop>
这一句改成org.hibernate.dialect.DB2Dialect,于是重启服务以后,打印的hql果真不再使用(+)这种外连接了,使用正规的left outer join...... 控制台也不再报那两种奇怪的异常了....这说明定义hibernate的方言搞错了,于是hibernate翻译的hql造成了错误.........

 

    我的问题OK了!.不用改一行代码..........

 

    这个博客里面又比较详细的外连接语法的解释和举例:
   
http://anjian0802.blog.163.com/blog/static/47988453201031803577/

 

 


 

分享到:
评论

相关推荐

    db2 错误码 大全

    在使用DB2数据库的过程中,可能会遇到各种各样的错误,了解这些错误码的意义及其解决方法对于数据库管理员来说至关重要。本文将详细介绍DB2中的常见错误码及其含义,帮助用户更好地理解并处理这些问题。 #### 一、...

    1585错误解决方案.docx

    在使用IBM DB2数据库时,有时可能会遇到错误代码SQL1585N,这表示当前系统中不存在具有足够页大小的系统临时表空间,导致某些操作无法执行。SQLSTATE=54048进一步确认了这是一个与表空间管理相关的错误。针对这个...

    DB2不允许访问表空间

    DB2SQLError: SQLCODE=-290, SQLSTATE=55039, SQLERRMC=null, DRIVER=3.50.152 消息:不允许访问表空间。SQLCODE=-290, SQLSTATE=55039, DRIVER=3.50.152 ``` 此错误提示中的`SQLCODE=-290`和`SQLSTATE=55039`表明...

    DB2数据库错误信息全面汇总

    在DB2中,SQLCODE和SQLSTATE是用来表示SQL语句执行结果的状态码。其中: - **SQLCODE**:是IBM DB2系统定义的一个整型变量,用于返回SQL语句执行的结果状态。 - **SQLSTATE**:是一个由五位字符组成的字符串,用来更...

    db2数据库错误解决代码sqlcode

    - SQLCODE -104表示语法错误,通常由于拼写错误、遗漏标点或不正确的SQL构造。修正SQL语句即可解决。 5. **预防措施**: - 使用强类型编程语言可以避免一些常见的数据类型错误。 - 在执行重要操作前备份数据,...

    DB2错误大全,SQL CODE错误信息

    在处理DB2数据库的过程中,我们经常会遇到各种各样的问题,其中很多问题都与SQL CODE和SQL State密切相关。本文将详细介绍一系列常见的SQLCODE和SQLState错误信息及其含义,旨在帮助用户更好地理解这些错误,并能够...

    db2数据库错误解决大全

    db2 数据库错误对照文档,错误分析及解决办法,常见的都有。db2数据库开发者最好的帮助文档。

    详解DB2 sqlstate 57016 SQLCODE=-668 原因码 "7"错误的快速解决办法

    在使用DB2过程中,可能会遇到各种错误代码,其中SQLSTATE 57016与SQLCODE -668,特别是原因码“7”,是一个常见的错误,通常表示在尝试执行数据库操作时遇到了权限问题。本篇文章将深入探讨这个错误的原因,并提供...

    DB2 sqlcode sqlstate 说明

    在DB2数据库管理系统中,当你执行SQL语句时,可能会遇到各种错误情况。DB2通过返回`sqlcode`和`sqlstate`来告知用户具体的错误信息,帮助开发者和管理员理解并解决问题。`sqlcode`是一个整数值,通常负值表示错误,...

    DB2的SQL、sqlcode、sqlstate错误码中文大全

    因此,本文旨在整理 DB2 的 SQL、sqlcode、sqlstate 错误码大全,提供详细的错误码说明和用户响应方法,帮助用户快速解决问题,提高工作效率。 SQL0000 - SQL0099 在 DB2 中,SQL0000 - SQL0099 错误码系列主要...

    对表进行任何操作都不被允许,提示SQLSTATE=57016 SQLCODE=-668 ,原因码 \"7\"的错误:SQL0668N Operation not

    在SQL数据库操作中,我们可能会遇到各种错误代码,其中SQLSTATE=57016 SQLCODE=-668是一个常见的错误,特别是在IBM DB2数据库系统中。这个错误通常表示一个操作无法执行,因为对象(如表)正被其他事务占用或者处于...

    详解DB2 sqlstate 57016 SQLCODE=-668 原因码 “7”错误的快速解决办法

    您可能感兴趣的文章:数据库触发器DB2和SqlServer有哪些区别DB2死锁的解决过程全记录CentOS下DB2数据库安装过程详解db2数据库常用操作命令大全DB2新手使用的一些小笔记:新建实例、数据库路径不存在、客户端连接 .db2...

    DB2常用错误信息大全

    然而,在使用DB2过程中,用户可能会遇到各种各样的错误信息,这些错误信息有时表述不够直观明确,导致问题排查变得困难。本文旨在通过解析一系列常见的DB2错误信息,帮助用户更好地理解和解决这些问题。 #### 二、...

    db2常见错误码及释义

    在使用DB2数据库管理系统的过程中,用户可能会遇到各种各样的错误提示。这些错误提示通常包含一个SQLCODE和SQLSTATE值,用来指示具体发生了什么类型的错误。理解这些错误码的意义对于快速定位问题、解决问题至关重要...

    DB2数据库错误代码

    在使用DB2数据库过程中,我们经常会遇到各种错误代码,这些错误代码对于诊断问题、理解数据库行为以及优化性能都非常重要。本文将基于提供的内容,详细介绍DB2中的错误代码及其含义。 #### 一、SQL执行成功(SQL ...

    DB2(DataBase2DataBase)数据库常见报错信息整理(汇总).rar

    关键字:SQL0104 SQLCODE -104 说明: Token &1 was not valid. 说明:令牌&1 无效。 关键字:SQL0106 SQLCODE -106 说明: Precision specified for FLOAT column not valid. 说明:为 FLOAT 列无效指定的精度。 ...

    DB2 SQLCODE 大全

    在DB2中,SQLCODE和SQLSTATE经常一起使用,以确保SQL语句的执行结果能够被准确地解读。 在提供的文件内容中,DB2 SQLCODE大全列出了大量可能的SQLCODE值及其对应的SQLSTATE值和说明。以下是文件内容中部分知识点的...

    DB2异常汇总-英文

    15. SQLCODE -104, SQLSTATE 42601: 令牌&1无效。有效令牌:&2。这表明语法错误,如拼写错误的关键词或操作符。 16. SQLCODE -105, SQLSTATE 42604: 混合或图形字符串常量无效。这通常涉及到非ASCII字符集的使用...

    db2 sqlcode中文说明

    通过对DB2 SQLCODE的理解和掌握,开发者可以在遇到数据库问题时更加迅速地定位问题所在,并采取合适的解决方案。此外,通过查阅官方文档或相关资料,还可以获取更多关于特定SQLCODE的详细信息。希望本文能够帮助您更...

    sqlcode

    理解DB2的SQLCode与SQLState不仅有助于快速诊断与解决问题,还能促进数据库性能优化与安全性提升。通过深入学习这些代码背后的含义,数据库专业人员能够更高效地管理和维护数据库系统,确保其稳定运行与数据完整性。...

Global site tag (gtag.js) - Google Analytics