【发布时间】:2012-11-10 23:06:43
【问题描述】:
假设有一个模式R(a,b),我的目标模式是S(a,b,foo(a,b)),其中foo应该是自定义函数。有没有实现这个目标的好方法?像 S = 从 R 中选择 a, b, foo(a, b)。
【问题讨论】:
标签: mysql function row user-defined-functions
假设有一个模式R(a,b),我的目标模式是S(a,b,foo(a,b)),其中foo应该是自定义函数。有没有实现这个目标的好方法?像 S = 从 R 中选择 a, b, foo(a, b)。
【问题讨论】:
标签: mysql function row user-defined-functions
您完全可以这样做,使用CREATE FUNCTION,然后(如有必要)使用CREATE VIEW:
DELIMITER ;;
CREATE FUNCTION foo ... ;
DELIMITER ;
CREATE VIEW S AS SELECT a, b, foo(a, b) FROM R;
或者,要创建S 的快照,请使用CREATE TABLE ... SELECT:
CREATE TABLE S SELECT a, b, foo(a, b) FROM R;
当然,如果您不需要在其他任何地方使用foo(),您也许可以简单地在SELECT 语句中表达它的值(但这似乎太简单了,不能成为问题):
SELECT a, b, a+b FROM R;
【讨论】: