加文哥 2024-03-08 17:44 采纳率: 15.8%
浏览 9

如果上面的sql 要子查询存储过程改怎么写呢?

select id sex,name from user ;
如果上面的sql 要子查询存储过程改怎么写呢?

select id sex,name,(CALL getSchedule(a.id,'WFC-001-004',200))as qty from user ;
以上写对吗?

  • 写回答

4条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2024-03-08 17:44
    关注

    引自免费微信小程序:皆我百晓生

    在SQL中,将子查询转换为存储过程的调用时,通常我们会创建一个存储过程来执行复杂的逻辑并返回结果集,然后在主查询中调用该存储过程。不过,并非所有SQL方言都支持直接在SELECT语句中调用存储过程并将其作为列值。MySQL是一个支持这种特性的数据库系统。

    对于您给出的例子,假设getSchedule是一个已经存在的存储过程,它接受用户ID、某种参数和日期作为输入,并返回用户的某个指标(例如,qty)。那么在MySQL中,您可以尝试这样写:

    DELIMITER //
    CREATE PROCEDURE GetQtyForUser(IN userId INT, IN someParam VARCHAR(255), IN someDate INT)
    BEGIN
      -- 这里是存储过程内部的SQL逻辑,用来获取指定用户和条件下的qty
      SELECT ... FROM schedule WHERE user_id = userId AND other_field = someParam AND date = someDate;
    END //
    DELIMITER ;
    
    -- 调用存储过程并在查询中使用其结果
    SELECT id, sex, name, (CALL GetQtyForUser(id, 'WFC-001-004', 200)) AS qty 
    FROM user;
    

    但是,实际上在MySQL中,我们不能直接在SELECT语句中像上述方式那样调用存储过程,需要通过临时表或者变量的方式间接实现。正确做法可能是先调用存储过程获取结果,再JOIN或INSERT INTO SELECT结果到临时表,最后结合主表查询:

    DELIMITER //
    CREATE PROCEDURE GetUserQtyData()
    BEGIN
      CREATE TEMPORARY TABLE TempQtyData (userId INT, qty INT);
      
      INSERT INTO TempQtyData (userId, qty)
      SELECT a.id, getSchedule(a.id, 'WFC-001-004', 200) 
      FROM user a;
    
      SELECT u.id, u.sex, u.name, t.qty
      FROM user u
      LEFT JOIN TempQtyData t ON u.id = t.userId;
    END //
    DELIMITER ;
    
    -- 调用存储过程获取最终数据
    CALL GetUserQtyData();
    

    请注意,上述代码仅为示例,实际应用中请根据getSchedule存储过程的实际功能以及数据库的具体结构进行调整。同时,请确保你的数据库系统支持相关特性。

    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 3月8日

悬赏问题

  • ¥15 WPF动态创建页面内容
  • ¥15 如何对TBSS的结果进行统计学的分析已完成置换检验,如何在最终的TBSS输出结果提取除具体值及如何做进一步相关性分析
  • ¥15 SQL数据库操作问题
  • ¥100 关于lm339比较电路出现的问题
  • ¥15 Matlab安装yalmip和cplex功能安装失败
  • ¥15 加装宝马安卓中控改变开机画面
  • ¥15 STK安装问题问问大家,这种情况应该怎么办
  • ¥15 关于罗技鼠标宏lua文件的问题
  • ¥15 halcon ocr mlp 识别问题
  • ¥15 已知曲线满足正余弦函数,根据其峰值,还原出整条曲线