Параметрированное ОБНОВЛЕНИЕ обоих ключей и значений не работает [дублировать]

Другое решение состоит в том, чтобы выполнить код через последовательный исполнитель nsynjs .

Если базовая функция многозначна

nsynjs будет последовательно оценивать все обещания и ставить обещания результат в свойство data:

function synchronousCode() {

    var getURL = function(url) {
        return window.fetch(url).data.text().data;
    };
    
    var url = 'https://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js';
    console.log('received bytes:',getURL(url).length);
    
};

nsynjs.run(synchronousCode,{},function(){
    console.log('synchronousCode done');
});

Если базовая функция не обещает

Шаг 1. Wrap с обратным вызовом в оболочку, совместимую с nsynjs (если у нее есть обещанная версия, вы можете пропустить этот тест):

var ajaxGet = function (ctx,url) {
    var res = {};
    var ex;
    $.ajax(url)
    .done(function (data) {
        res.data = data;
    })
    .fail(function(e) {
        ex = e;
    })
    .always(function() {
        ctx.resume(ex);
    });
    return res;
};
ajaxGet.nsynjsHasCallback = true;

Шаг 2. Вставить синхронную логику в функцию:

function process() {
    console.log('got data:', ajaxGet(nsynjsCtx, "data/file1.json").data);
}

Шаг 3. Выполнить функцию синхронно через nnsynjs:

nsynjs.run(process,this,function () {
    console.log("synchronous function finished");
});

Nsynjs будет оценивать все операторы и выражения шаг за шагом, приостанавливая выполнение в случае, если результат некоторой медленной функции не готов.

Дополнительные примеры здесь: https://github.com/amaksr/nsynjs/tree/master/examples

2
задан jj172 16 July 2014 в 22:04
поделиться

2 ответа

SOLVED:

Я вижу, что я делал неправильно. Единственное изменение, которое мне нужно было сделать, это добавить запятую после var_1, поскольку: «Для привязки позиционных переменных второй аргумент всегда должен быть последовательностью, даже если он содержит одну переменную. И помните, что для Python требуется запятая, чтобы создать сингл элементный кортеж ".

Например:

def delete(var_1):
    cur.execute(
    """DELETE FROM potluck 
    WHERE name = %s;""", (var_1,))

Это работает. Я получил информацию от:

http://initd.org/psycopg/docs/usage.html#sql-injection

Во втором случае , пожалуйста, обратитесь к другому ответу ниже, в котором используются AsIs. Это работает. Например:

def delete(name, var_1):
    cur.execute(
    """DELETE FROM potluck 
    WHERE %s = %s;""", (AsIs(name), var_1))

Это делает трюк. Спасибо!

1
ответ дан jj172 28 August 2018 в 14:13
поделиться

Для передачи идентификаторов используйте psycopg2.extensions.AsIs

from psycopg2.extensions import AsIs

def update(table_name, var_1, var_2):
    cur.execute("""
        UPDATE %s
        SET %s = 'Y'
        WHERE %s = 'John';
        """,
        (AsIs(table_name), AsIs(var_1), AsIs(var_2))
    )
4
ответ дан Clodoaldo Neto 28 August 2018 в 14:13
поделиться
Другие вопросы по тегам:

Похожие вопросы: