首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL设计;带有变量的视图或存储过程

MySQL设计;带有变量的视图或存储过程
EN

Stack Overflow用户
提问于 2012-11-05 15:53:57
回答 2查看 527关注 0票数 0

我必须执行一个复杂的查询,从7-8个表中选择几列。

我们不想用编程语言(在我们的例子中是PHP- Symfony 1.4/Propel 1.4 )编写查询,而是创建一个视图或存储过程来为开发人员提供非常简单的select查询。我很困惑什么才是更好的方法。

我们需要以下格式的查询:

代码语言:javascript
复制
SET @PlayerId = 1;

SELECT CASE WHEN mat.player1id = @PlayerId THEN mat.player2id ELSE mat.player1id END as opponent
    /*plus many other columns*/
FROM `wzo_matches` as mat /*plus few other tables*/
WHERE (mat.player1id =@PlayerId OR mat.player2id=@PlayerId)
    /*plus other join conditions*/

视图的问题是,SET @PlayerId=xx语句。我们事先不知道玩家id,但会通过PHP传递。我希望这是排除观点的理由;有什么解决办法吗?

其他选项将是存储过程。唯一的问题是,它将为每个查询创建一个新视图,因此数据库的操作将非常繁重。

有人能建议最好的方法,使开发人员可以从上面的查询获得所需的数据,而不是在PHP中编写上面的复杂查询。(显然是通过SP或view &简单的select查询)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-11-05 16:53:04

根据Can I create view with parameter in MySQL?的回复,我的问题被修复为以下问题:

代码语言:javascript
复制
create function getPlayer() returns INTEGER DETERMINISTIC NO SQL return @getPlayer;

create view getPlay as
    SELECT
        CASE WHEN play.hiderid = getPlayer() THEN play.seekerid ELSE play.hiderid END AS opponent, play . * 
        FROM odd_play play, odd_match mat
        WHERE (seekerid = getPlayer() OR hiderid = getPlayer())
        AND play.id = mat.latestplay;

select play.*
from (select @getPlayer:=1 p) ply, getPlay play;
票数 0
EN

Stack Overflow用户

发布于 2012-11-05 16:01:40

代码语言:javascript
复制
CREATE PROCEDURE SELECT_PLAYER(p INT) SET @PlayerId  = p
SELECT CASE WHEN mat.player1id = @PlayerId THEN mat.player2id ELSE mat.player1id END as opponent
    /*plus many other columns*/
FROM `wzo_matches` as mat /*plus few other tables*/
WHERE (mat.player1id =@PlayerId OR mat.player2id=@PlayerId)
    /*plus other join conditions*/
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13228026

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档