использовать набор результатов, возвращаемый WL.Server.invokeSQLStatement в процедуре адаптера sql

Я хочу использовать resultSet, возвращаемый вызовом оператора SQL через оператор WL.Server.invokeSQLStatement в процедуре адаптера SQL внутри самой процедуры.

Я попробовал способ, который мы обычно делаем, используя result.invocationResult.resultSet[variable].Property внутри процедуры адаптера SQL, но он не работает.

HTML

    <div data-role="page" id="mainPage">
        <div data-role="header">search medicine</div>
            <br>

            <hr>
            <div data-role="content">       
                <input type="text" value="MEDICINE" id="medicine"><hr>
                <input type="text" value="LOCATION" id="location"><hr>
                <input type="submit" id="search" value="SEARCH">
            </div>
        </div>

        <div id="itemsList" data-role="page">
            <table id="myTable" border="1">
                <tr>
                    <th>Registration No</th>
                </tr>
            </table>    
            <div data-role="header">gg</div>
            <div data-role="content"></div>
        </div>

JavaScript

window.$ = window.jQuery = WLJQ;
function wlCommonInit() {

}

$(document).ready(function(){
    $("#search").click(function(){
        GetEmployeeData();  
    });
});

function GetEmployeeData() {        
    var medicine= $("#medicine").val();
    var location=$("#location").val();
    alert(medicine);
    var invocationData = {
        adapter : 'ATM',
        procedure : 'getStudentInfos',
        parameters: [medicine,location]
    };

    WL.Client.invokeProcedure(invocationData,{
        onSuccess : loadFeedsSuccess,
        onFailure : loadFeedsFailure
    });
}

function loadFeedsSuccess(result){      
    alert("Hii");
    WL.Logger.debug("Feed retrieve success");

    if (result.invocationResult.resultSet.length>0) 
        displayFeeds(result.invocationResult.resultSet);
    else 
        loadFeedsFailure();     
}

function loadFeedsFailure(result){      
    alert("H");
}

function displayFeeds(items){
    alert("ii");
    var table = document.getElementById("myTable");
    for(var i=0;i<items.length;i++)
        {
            // Create an empty <tr> element and add it to the 1st position of the table:
            var row = table.insertRow(i+1); 
            var cell1 = row.insertCell(0);

            // Add some text to the new cells:
            cell1.innerHTML = items[i].RegNo;
        }
}

function LoadResultPage() {
    $("AppDiv").hide();
    $("#itemsList").show();
};

JavaScript-адаптер

 var selectStatement2 = WL.Server.createSQLStatement("select LocId from location WHERE LocName= ? ");
    var selectStatement3 = WL.Server.createSQLStatement("select RegNo from storeloc WHERE LocId= ? ");

    function getStudentInfos(Name,Location) {    
        var result=WL.Server.invokeSQLStatement({
            preparedStatement : selectStatement2,
            parameters : [Location]
        });

       var a = result.invocationResult.resultSet;
       if(a.length>0)
       var LocId=a[0].LocId;
       return WL.Server.invokeSQLStatement({
        preparedStatement : selectStatement3,
            parameters : [LocId]
        });     
    }

В Chrome я получаю следующую ошибку

Ошибка вызова процедуры. Ошибка Ecma: TypeError: невозможно прочитать свойство «resultSet» из неопределенного (E% 3A% 5CPRACTICE% 5CATM% 5Cadapters% 5CATM/ATM-impl.js # 25). Моя строка № 25 — это var a = result.invocationResult.resultSet;


person user3476186    schedule 30.03.2014    source источник
comment
Не работает... отлично. :) В каком контексте вы это пробовали? Это технический веб-сайт QA&. Добавьте фрагменты кода, добавьте любые ошибки, которые вы получаете. Откройте инструменты разработчика Chrome при предварительном просмотре своего приложения. Что вы видите? Пожалуйста, добавьте эту информацию к Вопросу.   -  person Idan Adar    schedule 30.03.2014
comment
я изменил свой вопрос   -  person user3476186    schedule 30.03.2014
comment
Можете ли вы предоставить сценарий SQL для воссоздания вашей базы данных? (обратите внимание, что я буду использовать MySQL, а не DB2... на случай, если это ваш тип базы данных)   -  person Idan Adar    schedule 30.03.2014
comment
имя моего db - «medurge», которое содержит 2 таблицы: 1) location 2) storeloc, на которые ссылаются в приведенном выше вопросе. Таблица location имеет следующие атрибуты LocId (первичный ключ) varchar 10, LocName varchar 40.   -  person user3476186    schedule 30.03.2014
comment
Таблица storeloc имеет два атрибута RegNo(первичный ключ) varchar30,LocId varchar10   -  person user3476186    schedule 30.03.2014


Ответы (1)


Вместо этого попробуйте изменить реализацию JavaScript вашего адаптера на следующую.

Я попробовал версию этого с другой таблицей и переменными, и это сработало для меня (по крайней мере, вызов адаптера из Worklight Studio).

Обратите внимание, что я использую locId.resultSet, а не locId.invocationResult.resultSet. Последний используется на клиентской, а первый — на серверной.

Также обратите внимание на разделение на две функции.

function getStudentInfos(Name,Location) {
    var locId, a, b;

    locId = getlocId(Location);
    a = locId.resultSet;
    if (a && a.length>0) {
        b = a[0].LocId;
    }
    return WL.Server.invokeSQLStatement({
        preparedStatement : selectStatement3,
        parameters : [b]
    });
}

function getlocId (Location) {
    var result = WL.Server.invokeSQLStatement({
        preparedStatement : selectStatement2,
        parameters : [Location]
    });
    return result;
}

Обратите внимание на оператор if... не забудьте добавить туда обработку ошибок...

person Idan Adar    schedule 31.03.2014
comment
Посмотрите слева от моего ответа... он показывает знак V. Нажмите на нее. - person Idan Adar; 01.04.2014
comment
Да, я сделал это. Спасибо. Можете ли вы помочь мне со вторым вопросом, который я задал, вот ссылка stackoverflow.com/questions/22783175/ - person user3476186; 01.04.2014
comment
@ user3476186, теперь на ваш второй вопрос есть ответ. Просмотрите его. - person Idan Adar; 05.05.2014