最近给公司做财务运营计费系统,需要把一个包含大量公式的 excel 转化为 mysql。excel 里面有 VLOOKUP,IF 等各种类型的公式,VLOOKUP 我用子查询实现,IF 用 CASE WHEN THEN END 实现。现在遇到这样一个问题:
SELECT *, (SELECT A FROM CIC WHERE CIC.PROJECT_ALIAS=C.PROJECT_ALIAS) AS CHARGE_MODE, CASE WHEN CHARGE_MODE='分钟' THEN F1 ELSE F2 END FROM C
这样一个 SQL 语句报错,说找不到 CHARGE_MODE。(这是简化了的 sql 示意)
也就是说想在 SELECT 后面的列中使用前面的列的别名,结果报错。不知道有没有什么的办法绕过这一问题?
实在不行只有用嵌套的 SELECT,在外层的 SELECT 中使用里层 SELECT 的列别名,但是财务的 excel 公式特别多,这样处理需要嵌套很多层,估计查询速度会很慢。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.