AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 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

带有 EXEC 存储过程参数的 Express JS API 查询变量

  • 772

我正在使用 API,它将作为我的项目架构中的数据访问层。

这是我的 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');

它与该设置配合良好。

但是,如果参数比预期的多,我想在保持相同结果的情况下提高 API 查询的可读性。

因此我使用变量和反引号来使用这些方法:

使用 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);

不带 req.body

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);

两者都无法通过我的 Flutter 项目中的此 API 调用来处理请求:

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

这就是有req.body.[param]和没有的req.body.[param]日志内容:

未捕获的异常:异常:无法发出 POST 请求:异常:API 错误:500 {消息:'EXEC testStoredProcedure @user_id = null, @img_data = '', '.} 附近的语法不正确

根据日志,指定参数附近的语法EXEC testStoredProcedure不正确。因此,我在这里遗漏了什么?

javascript
  • 1 1 个回答
  • 62 Views

1 个回答

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

    如果尝试的所有方法均无效,即使其中存在解决方法。

    以下解决方案可以提高可读性并提供相同的结果:

    替换此代码片段:

    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);
    

    使用以下代码片段:

    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);
    

    您会注意到req.body变量已被删除,并且我发现单引号(' )导致了语法不正确的异常。

    编辑:优化 API 控制器函数的结构

    此代码片段引入了不适当的设置:

    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);
    

    它应该被重构为:

    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');
    

    删除查询变量因为它是多余的,并重构.query(query)并将其更改为.execute('testStoredProcedure')。

    我希望它能对未来的读者有所帮助!;)

    • 1

相关问题

  • 合并排序不起作用 - Javascript代码:即使在调试后也无法找到错误

  • select.remove() 方法工作得很奇怪[关闭]

  • useOpenWeather() 中总是出现 401 res -react-open-weather lib [重复]

  • 输入元素没有只读属性,但字段仍然不可编辑[关闭]

  • 如何编辑 D3.js RadialTree 的第一个节点半径?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

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

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve