<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    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 滌生 閱讀(3365) 評論(6)  編輯  收藏


    FeedBack:
    # re: ibatis JshopStore5的sqlmap的xml錯誤,NestedSQLException錯誤[未登錄]
    2007-01-16 17:06 | junmy
    posted on 2006-05-22 00:42
    http://www.tkk7.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

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 全黄A免费一级毛片| 国产成人精品日本亚洲直接 | 69视频免费在线观看| 在线观看亚洲天天一三视| 自拍偷自拍亚洲精品播放| 国产精品无码免费视频二三区| 亚洲愉拍一区二区三区| 青青草免费在线视频| 亚洲日本在线电影| 性感美女视频在线观看免费精品| 亚洲AV无码一区二区三区人 | 亚洲国产AV无码专区亚洲AV| 丰满人妻一区二区三区免费视频| 国产精品亚洲产品一区二区三区| 成人一级免费视频| 亚洲午夜久久久久久噜噜噜| 免费萌白酱国产一区二区三区 | 免费看污成人午夜网站| 中文字幕 亚洲 有码 在线| 毛片免费观看的视频| 美女视频黄视大全视频免费的| 亚洲国产精品日韩| 97超高清在线观看免费视频| 久久青青草原亚洲av无码app| 99久久99久久精品免费看蜜桃| 亚洲一卡2卡三卡4卡无卡下载 | 九九综合VA免费看| 亚洲午夜久久久久久久久久| 99视频在线看观免费| 亚洲资源最新版在线观看| 国产在线19禁免费观看国产 | 亚洲美女视频网站| 成全视频在线观看免费高清动漫视频下载 | 久久久亚洲精华液精华液精华液 | 免费人成视频在线观看视频| 高清永久免费观看| 亚洲福利视频一区二区三区| 男女交性永久免费视频播放| 福利免费在线观看| 中文字幕亚洲综合小综合在线| 亚洲人成人网站在线观看|