AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 79410575
Accepted
DevQtPH
DevQtPH
Asked: 2025-02-04 12:29:27 +0800 CST2025-02-04 12:29:27 +0800 CST 2025-02-04 12:29:27 +0800 CST

Variável de consulta da API Express JS com parâmetros para procedimento armazenado EXEC

  • 772

Estou trabalhando com a API que servirá como minha camada de acesso a dados na arquitetura do meu projeto.

Esta é a forma original da minha configuração de consulta de API:

const pool = await poolPromise;
const request = pool.request();
const result = await request.input('user_id', sql.NVarChar(50), user_id || null)
    .input('img_data', sql.VarBinary(sql.MAX), Buffer.from(img_data))
    .input('img_size', sql.Decimal(10, 3), img_size)
    .input('birthday', sql.Date, birthday)
    .input('country', sql.VarChar(200), country)
    .input('email_add', sql.NVarChar(150), email_add)
    .input('mobile_no', sql.VarChar(50), mobile_no)
    .input('key', sql.VarChar(100), key)
    .query('EXEC testStoredProcedure @user_id, @img_data, @img_size, @birthday, @country, @email_add, @mobile_no, @key');

Funciona bem com essa configuração.

No entanto, se houver mais parâmetros do que o esperado, quero melhorar a legibilidade da consulta da API com os mesmos resultados.

Então eu uso essas abordagens usando variáveis ​​e acentos graves :

com req.body.[param]

const query = `
    'EXEC testStoredProcedure
    @user_id = ${req.body.user_id},
    @img_data = ${req.body.img_data},
    @img_size = ${req.body.img_size},
    @birthday = ${req.body.birthday},
    @country = ${req.body.country},
    @email_add = ${req.body.email_add},
    @mobile_no = ${req.body.mobile_no},
    @key = ${req.body.key}'
`;

const pool = await poolPromise;
const request = pool.request();
const result = await request.input('user_id', sql.NVarChar(50), user_id || null)
    .input('img_data', sql.VarBinary(sql.MAX), Buffer.from(img_data))
    .input('img_size', sql.Decimal(10, 3), img_size)
    .input('birthday', sql.Date, birthday)
    .input('country', sql.VarChar(200), country)
    .input('email_add', sql.NVarChar(150), email_add)
    .input('mobile_no', sql.VarChar(50), mobile_no)
    .input('key', sql.VarChar(100), key)
    .query(query);

sem req.corpo

const query = `
    'EXEC testStoredProcedure
    @user_id = ${user_id},
    @img_data = ${img_data},
    @img_size = ${img_size},
    @birthday = ${birthday},
    @country = ${country},
    @email_add = ${email_add},
    @mobile_no = ${mobile_no},
    @key = ${key}'
`;

const pool = await poolPromise;
const request = pool.request();
const result = await request.input('user_id', sql.NVarChar(50), user_id || null)
    .input('img_data', sql.VarBinary(sql.MAX), Buffer.from(img_data))
    .input('img_size', sql.Decimal(10, 3), img_size)
    .input('birthday', sql.Date, birthday)
    .input('country', sql.VarChar(200), country)
    .input('email_add', sql.NVarChar(150), email_add)
    .input('mobile_no', sql.VarChar(50), mobile_no)
    .input('key', sql.VarChar(100), key)
    .query(query);

Ambos falham ao processar a solicitação por meio desta chamada de API do meu projeto Flutter:

await _api.testMethod(
    '/api/request', // route
    null, // user_id
    '', // img_data
    0.00, // img_size
    DateTime.now().toIso8601String(), // birthday
    'Philippines', // country
    null, // email_add
    _mobileNo, // mobile_no
    'SIGN_IN'); // key

Isto é o que os logs dizem para comreq.body.[param] e semreq.body.[param] :

Exceção não capturada: Exceção: Falha ao fazer solicitação POST: Exceção: Erro de API: 500 {mensagem: Sintaxe incorreta perto de 'EXEC testStoredProcedure @user_id = null, @img_data = '', '.}

De acordo com os logs, a sintaxe near especificando o parâmetro for EXEC testStoredProcedureestá incorreta. Portanto, o que estou perdendo aqui?

javascript
  • 1 1 respostas
  • 62 Views

1 respostas

  • Voted
  1. Best Answer
    DevQt
    2025-02-04T14:44:21+08:002025-02-04T14:44:21+08:00

    Se nenhuma das abordagens tentadas funcionar, mesmo que haja uma solução alternativa.

    Aqui está a solução que melhora a legibilidade e também fornece os mesmos resultados:

    Substitua este trecho de código:

    const query = `
        'EXEC testStoredProcedure
        @user_id = ${user_id},
        @img_data = ${img_data},
        @img_size = ${img_size},
        @birthday = ${birthday},
        @country = ${country},
        @email_add = ${email_add},
        @mobile_no = ${mobile_no},
        @key = ${key}'
    `;
    
    const pool = await poolPromise;
    const request = pool.request();
    const result = await request.input('user_id', sql.NVarChar(50), user_id || null)
        .input('img_data', sql.VarBinary(sql.MAX), Buffer.from(img_data))
        .input('img_size', sql.Decimal(10, 3), img_size)
        .input('birthday', sql.Date, birthday)
        .input('country', sql.VarChar(200), country)
        .input('email_add', sql.NVarChar(150), email_add)
        .input('mobile_no', sql.VarChar(50), mobile_no)
        .input('key', sql.VarChar(100), key)
        .query(query);
    

    com este trecho de código:

    const query = `
        EXEC testStoredProcedure
        @user_id,
        @img_data,
        @img_size,
        @birthday,
        @country,
        @email_add,
        @mobile_no,
        @key`;
    
    const pool = await poolPromise;
    const request = pool.request();
    const result = await request.input('user_id', sql.NVarChar(50), user_id || null)
        .input('img_data', sql.VarBinary(sql.MAX), Buffer.from(img_data))
        .input('img_size', sql.Decimal(10, 3), img_size)
        .input('birthday', sql.Date, birthday)
        .input('country', sql.VarChar(200), country)
        .input('email_add', sql.NVarChar(150), email_add)
        .input('mobile_no', sql.VarChar(50), mobile_no)
        .input('key', sql.VarChar(100), key)
        .query(query);
    

    Você notará que req.bodyas variáveis ​​são removidas e descobri que as aspas simples ( ' ) causam a exceção de sintaxe incorreta .

    Editar: otimizar a estrutura da função do controlador da API

    Este trecho de código introduz uma configuração inadequada:

    const query = `
        EXEC testStoredProcedure
        @user_id,
        @img_data,
        @img_size,
        @birthday,
        @country,
        @email_add,
        @mobile_no,
        @key`;
    
    const pool = await poolPromise;
    const request = pool.request();
    const result = await request.input('user_id', sql.NVarChar(50), user_id || null)
        .input('img_data', sql.VarBinary(sql.MAX), Buffer.from(img_data))
        .input('img_size', sql.Decimal(10, 3), img_size)
        .input('birthday', sql.Date, birthday)
        .input('country', sql.VarChar(200), country)
        .input('email_add', sql.NVarChar(150), email_add)
        .input('mobile_no', sql.VarChar(50), mobile_no)
        .input('key', sql.VarChar(100), key)
        .query(query);
    

    e deve ser refatorado em:

    const pool = await poolPromise;
    const request = pool.request();
    const result = await request.input('user_id', sql.NVarChar(50), user_id || null)
        .input('img_data', sql.VarBinary(sql.MAX), Buffer.from(img_data))
        .input('img_size', sql.Decimal(10, 3), img_size)
        .input('birthday', sql.Date, birthday)
        .input('country', sql.VarChar(200), country)
        .input('email_add', sql.NVarChar(150), email_add)
        .input('mobile_no', sql.VarChar(50), mobile_no)
        .input('key', sql.VarChar(100), key)
        .execute('testStoredProcedure');
    

    Remova a variável de consulta porque ela é redundante, refatore-a .query(query)e altere-a para .execute('testStoredProcedure').

    Espero que ajude os futuros leitores! ;)

    • 1

relate perguntas

  • classificação de mesclagem não está funcionando - código Javascript: não é possível encontrar o erro mesmo após a depuração

  • método select.remove() funciona estranho [fechado]

  • Sempre um 401 res em useOpenWeather () - react-open-weather lib [duplicado]

  • O elemento de entrada não possui atributo somente leitura, mas os campos ainda não podem ser editados [fechado]

  • Como editar o raio do primeiro nó de um RadialTree D3.js?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve