posts - 11,  comments - 28,  trackbacks - 0
          今天在繼續研究JShopStore時候,在查看product的明細時即
          執行action
          ????<action?path="/shop/viewItem"?type="org.apache.struts.beanaction.BeanAction"
          ????????????name
          ="catalogBean"?scope="session"
          ????????????validate
          ="false"?input="/catalog/Product.jsp">
          ??????
          <forward?name="success"?path="/catalog/Item.jsp"/>
          ????
          </action>
          報NestedSqlException錯誤,錯誤的核心部分如下:
          Caused?by:?com.ibatis.dao.client.DaoException:?Failed?to?execute?queryForObject?-?id?[getItem],?parameterObject?[EST-18].??Cause:?com.ibatis.common.jdbc.exception.NestedSQLException:???
          ---?The?error?occurred?in?com/ibatis/jpetstore/persistence/sqlmapdao/sql/Item.xml.??
          ---?The?error?occurred?while?applying?a?parameter?map.??
          ---?Check?the?getItem-InlineParameterMap.??
          ---?Check?the?statement?(query?failed).??
          ---?Cause:?java.sql.SQLException:?[Microsoft][SQLServer?2000?Driver?for?JDBC][SQLServer]???'itemid'?????
          Caused?by:?java.sql.SQLException:?[Microsoft][SQLServer?
          2000?Driver?for?JDBC][SQLServer]???'itemid'?????
          Caused?by:?com.ibatis.common.jdbc.exception.NestedSQLException:???
          ---?The?error?occurred?in?com/ibatis/jpetstore/persistence/sqlmapdao/sql/Item.xml.??
          ---?The?error?occurred?while?applying?a?parameter?map.??
          ---?Check?the?getItem-InlineParameterMap.??
          ---?Check?the?statement?(query?failed).??
          ---?Cause:?java.sql.SQLException:?[Microsoft][SQLServer?2000?Driver?for?JDBC][SQLServer]???'itemid'?????
          我跟蹤、跟蹤,跟蹤到ItemSqlMapDao
          ??public?Item?getItem(String?itemId)?{
          ????Integer?i?
          =?(Integer)?queryForObject("getInventoryQuantity",?itemId);
          ????Item?item?
          =?(Item)?queryForObject("getItem",?itemId);
          ????item.setQuantity(i.intValue());
          ????
          return?item;
          ??}
          找到錯誤語句
          Item item = (Item) queryForObject("getItem", itemId);
          繼續跟蹤到操縱的sql_map文件Item.xml
          <select?id="getItem"?resultClass="item"?parameterClass="string"?cacheModel="quantityCache">
          ????select
          ??????ITEMID,
          ??????LISTPRICE,
          ??????UNITCOST,
          ??????SUPPLIER?AS?supplierId,
          ??????I.PRODUCTID?AS?"product.productId",
          ??????NAME?AS?"product.name",
          ??????DESCN?AS?"product.description",
          ??????CATEGORY?AS?"product.categoryId",
          ??????STATUS,
          ??????ATTR1?AS?attribute1,
          ??????ATTR2?AS?attribute2,
          ??????ATTR3?AS?attribute3,
          ??????ATTR4?AS?attribute4,
          ??????ATTR5?AS?attribute5,
          ??????QTY?AS?quantity
          ????from?ITEM?I,?INVENTORY?V,?PRODUCT?P
          ????where?P.PRODUCTID?=?I.PRODUCTID
          ??????and?I.ITEMID?=?V.ITEMID
          ??????and?I.ITEMID?=?#value#
          ??
          </select>
          問題就出現在這,Item類中包含了Product類,出現NestedSqlException錯誤。
          查閱了ibatis幫助,此處sql_map的嵌套類寫法是正確的。我又將這個sql語句拷貝到MsSqlServer中執行,結果也是正確的。陷入困惑。
          在網上找資料,發現了一個英文網站中指明了
          ---?Cause:?java.sql.SQLException:?[DataDirect][SQLServer?JDBC?Driver][SQLServer]Ambiguous?column?name?'itemid'.?
          哈哈,問題就此找到了。即itemid列指待不清,應該將ITEMID替換成I.ITEMID AS ITEMID。而之所以我直接將語句拷貝到MsSqlServer執行正確,是因為MSSqlServer自動做了處理,加上了表的別名。而這個Sql語句本身是存在問題的。
          所以item.xml替換后的代碼為
          ??<select?id="getItem"?resultClass="item"?parameterClass="string"?cacheModel="quantityCache">
          ????select
          ??????I.ITEMID?AS?ITEMID,
          ??????LISTPRICE,
          ??????UNITCOST,
          ??????SUPPLIER?AS?supplierId,
          ??????I.PRODUCTID?AS?"product.productId",
          ??????NAME?AS?"product.name",
          ??????DESCN?AS?"product.description",
          ??????CATEGORY?AS?"product.categoryId",
          ??????STATUS,
          ??????ATTR1?AS?attribute1,
          ??????ATTR2?AS?attribute2,
          ??????ATTR3?AS?attribute3,
          ??????ATTR4?AS?attribute4,
          ??????ATTR5?AS?attribute5,
          ??????QTY?AS?quantity
          ????from?ITEM?I,?INVENTORY?V,?PRODUCT?P
          ????where?P.PRODUCTID?=?I.PRODUCTID
          ??????and?I.ITEMID?=?V.ITEMID
          ??????and?I.ITEMID?=?#value#
          ??
          </select>
          問題解決,OK!誒,亂碼也耽誤了一些時間,否則早就解決了,看來亂碼誤事啊!
          posted on 2007-01-16 13:38 滌生 閱讀(3367) 評論(6)  編輯  收藏


          FeedBack:
          # re: ibatis JshopStore5的sqlmap的xml錯誤,NestedSQLException錯誤[未登錄]
          2007-01-16 17:06 | junmy
          posted on 2006-05-22 00:42
          http://www.aygfsteel.com/wujun/archive/2006/05/22/47392.html
          早就發現了~
            回復  更多評論
            
          # re: ibatis JshopStore5的sqlmap的xml錯誤,NestedSQLException錯誤
          2007-01-16 20:21 | 滌生
          @junmy
          今天我還在blogjava上找了一圈,沒找到對應的。要是早看到你的大作,可以省我半個上午的時間  回復  更多評論
            
          # re: ibatis JshopStore5的sqlmap的xml錯誤,NestedSQLException錯誤[未登錄]
          2007-01-18 19:44 | BeanSoft
          強烈建議 dudu 加入全文索引... 沒搜索這么多 blog 也是很浪費啊...  回復  更多評論
            
          # re: ibatis JshopStore5的sqlmap的xml錯誤,NestedSQLException錯誤
          2008-10-20 20:40 | Guest
          我也是這樣改的,不過仍然還是錯誤。。。搞不明白呢。  回復  更多評論
            
          # re: ibatis JshopStore5的sqlmap的xml錯誤,NestedSQLException錯誤
          2010-02-06 13:09 | ossoftwaare
          好內容,以前研究過,不過好久了, 最近寫了幾句,也發現了這個問題  回復  更多評論
            
          # re: ibatis JshopStore5的sqlmap的xml錯誤,NestedSQLException錯誤
          2010-12-10 14:48 | LingShame
          @junmy
          你走得路,先人已經走過N多次了.
          你再走來,不覺得可恥嗎?  回復  更多評論
            

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          <2007年1月>
          31123456
          78910111213
          14151617181920
          21222324252627
          28293031123
          45678910

          常用鏈接

          留言簿(5)

          隨筆檔案

          UML

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 保定市| 晋宁县| 马公市| 凤阳县| 西贡区| 邢台县| 宁国市| 新民市| 藁城市| 新平| 巴中市| 丹阳市| 丹东市| 永仁县| 新昌县| 边坝县| 全椒县| 会东县| 鄂托克旗| 德庆县| 化德县| 射阳县| 五指山市| 连山| 安庆市| 杨浦区| 高青县| 南召县| 灌阳县| 万盛区| 岑巩县| 简阳市| 玛曲县| 平昌县| 河源市| 扎赉特旗| 宁城县| 临夏县| 邵阳市| 岳西县| 兰州市|