Почему я получаю SqlMapException при вставке данных? - PullRequest
3 голосов
/ 08 апреля 2011

Я пытаюсь использовать iBatis, чтобы вставить некоторые данные, отправленные пользователем, в форму обратной связи.

Я использую установку Liferay / Spring MVC / iBatis / MySQL, но я думаю, что проблема вызвана конфигурацией iBatis. Всякий раз, когда я пытаюсь вставить данные, я вижу исключение в журналах:

com.ibatis.sqlmap.client.SqlMapException: There is no statement named contactus.ibatorgenerated_insert in this SqlMap.
        at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.getMappedStatement(SqlMapExecutorDelegate.java:231)
        at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.insert(SqlMapExecutorDelegate.java:367)
        at com.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.insert(SqlMapSessionImpl.java:82)
        at com.ibatis.sqlmap.engine.impl.SqlMapClientImpl.insert(SqlMapClientImpl.java:58)

Созданная ibator карта sql содержит содержит запрос вставки с идентификатором "ibatorgenerated_insert" с пространством имен "contact_us"

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">
<sqlMapConfig>
<sqlMap namespace="contactus">
        <insert id="ibatorgenerated_insert" parameterClass="contactUs.dao.ContactUs">
            <!--
            WARNING - This element is automatically generated by Apache iBATIS ibator, do not modify.
            This element was generated on Thu Apr 07 15:17:57 BST 2011.
            -->
            insert into contactus (email_address, first_name, last_name, company, timestamp,
            status, message)
            values (#emailAddress:VARCHAR#, #firstName:VARCHAR#, #lastName:VARCHAR#, #company:VARCHAR#,
            #timestamp:TIMESTAMP#, #status:VARCHAR#, #message:LONGVARCHAR#)
            <selectKey resultClass="java.lang.Integer" keyProperty="contactusId">
                SELECT LAST_INSERT_ID()
            </selectKey>
        </insert>
    </sqlMap>
</sqlMapConfig>

Что может быть причиной того, что iBatis не может найти оператор в файле XML? Я предполагаю, что он находит файл, так как он не сообщает о каких-либо других ошибках.

Ответы [ 2 ]

4 голосов
/ 08 апреля 2011

Я надеюсь, что вы указали файл contactus.xml , который содержит оператор вставки в SqlMapConfig.xml , как показано ниже

<sqlMapConfig>
    <properties resource="Connection.properties"/>
    <!-- Configure a built-in transaction manager.  If you're using an        app server, you probably want to use its transaction manager        and a managed datasource -->
<settings cacheModelsEnabled="false" enhancementEnabled="true"
  lazyLoadingEnabled="true" maxRequests="32" maxSessions="1"
    useStatementNamespaces="false" />
  <transactionManager type="JDBC">
    <dataSource type="JNDI">
        <property name="DataSource" value="${connection.datasource}"/>
    </dataSource>
  </transactionManager>
 <!-- List the SQL Map XML files. They can be loaded from the        classpath, as they are here (com.domain.data...) -->
    <sqlMap resource="contactus.xml"/>
</sqlMapConfig>

Вызов без пространства имен. Что-то вроде ниже

sqlMapper.insert("ibatorgenerated_insert",params);
1 голос
/ 08 апреля 2011

Попробуйте добавить следующее к вашему <sqlMapConfig> элементу:

<settings useStatementNamespaces="true"/>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...