Код ниже работает, если я предоставляю только один параметр. Если я выберу Германию и Мексику из раскрывающегося списка, по запросу ничего не будет возвращено, несмотря на данные, имеющиеся в таблице
Код внешнего интерфейса. Отправка параметров через AJAX jQuery .post
$('select').selectpicker();
var field1 = $('#field1').val();
$.post('data.js', {
field1: field1
})
На стороне сервера app.js:
app.post('/data.js', function(req, res) {
var thequery1 = `SELECT top 10 country
,[ Sales] sales
,[Units Sold] as sold
,FORMAT( Date, 'dd/MM/yyyy', 'en-US' ) thedate
FROM easternsun.dbo.financial
where 1 = 1`
if (req.body.field1) {
thequery1 = thequery1 + ' and country in (@field1)'
}
});
Promise.all([queryTablewithPararams(thequery1, req.body.field1)])
.then(
data => res.json(data)
);
function queryTablewithPararams(thequery1, field1) {
return new Promise(function(resolve, reject) {
var con = new msSqlConnecter.msSqlConnecter(config);
con.connect().then(function() {
new con.Request(thequery1)
.addParam("field1", TYPES.VarChar, field1 )
.onComplate(function(count, datas) {
resolve(datas);
}).onError(function(err) {
console.log(err);
}).Run();
}).catch(function(ex) {
console.log(ex);
});
});
}
Мой HTML-код для выпадающего списка:
<select id="field1" class="selectpicker form-control" multiple >
<option value="Canada">Canada</option>
<option value="Germany">Germany</option>
<option value="France">France</option>
<option value="Mexico">Mexico</option>
</select>
IЯ уверен, что мне нужно что-то добавить в эту строку, но я не знаю, что.
.addParam("field1", TYPES.VarChar, field1 )