mysql 视图和函数区别是什么,自定义函数 与 视图 在使用上有什么区别?

测试环境: PostgreSQL

测试用例:

CREATE TABLE a (

aid serial PRIMARY KEY,

name varchar(20)

);

CREATE TABLE b (

bid serial PRIMARY KEY,

name varchar(20)

);

CREATE TABLE ab (

abid serial PRIMARY KEY,

aid serial REFERENCES a(aid),

bid serial REFERENCES b(bid)

);

CREATE VIEW v_ab

AS

SELECT a.name AS "aname",

b.name AS "bname",

ab.abid AS "abid"

FROM a, b, ab

WHERE a.aid = ab.aid

AND b.bid = ab.bid;

CREATE FUNCTION f_ab(int)

RETURNS TABLE(aname varchar, bname varchar) AS $$

SELECT a.name AS "aname",

b.name AS "bname"

FROM a, b, ab

WHERE a.aid = ab.aid

AND b.bid = ab.bid

AND ab.abid = $1

$$ LANGUAGE SQL;

INSERT INTO a VALUES (1, 'a');

INSERT INTO b VALUES (2, 'b');

INSERT INTO ab VALUES (12, 1, 2);

这两篇文章把我搞糊涂了:慎用自定义函数和通过自定义函数提高服务器性能

抱着"存在即合理"的想法,我想知道到底什么时候该使用自定义函数?

另外,当数据量较大时,下面这两条语句执行效率上有区别吗?

SELECT aname, bname FROM v_ab WHERE abid = 12;

SELECT aname, bname FROM f_ab(12);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值