目录示例Stored vs Virtual限制说明postgresql中生成列是从其他列计算而来的特殊列。生成列与普通列不同,不是固定的值,而是又引用表中其他列的表达式决定的。生成列在sql标准(ISO/IEC 9075
postgresql中生成列是从其他列计算而来的特殊列。生成列与普通列不同,不是固定的值,而是又引用表中其他列的表达式决定的。生成列在sql标准(ISO/IEC 9075)中引入,被主流RDBMS支持,PostgreSQL12开始支持生成列。
下面首先创建一张表,用于演示PostgreSQL生成列:
CREATE TABLE Students (
Id INTEGER PRIMARY KEY,
FirstName VARCHAR(50),
LastName VARCHAR(50),
FullName VARCHAR(101) GENERATED ALWAYS AS (FirstName || ' ' || LastName) STORED
);
上面示例中最后一列是生成列,PostgreSQL生成列在定义中必须有GENERATED ALWAYS
(通常其他关系型数据库为可选)。另外生成列结尾必须有STORED
。这指定了生成列需要被存储(相对于virtual
,下面有解释),其他关系型数据库这通常也是可选的(默认值为virtual)。
生成列的语法如下:
<column_name> <datatype> GENERATED ALWAYS AS(expression) [STORED|VIRTUAL]
在GENERATED ALWAYS AS (expression) Stored子句中,使用现有的列指定生成列表达式,为生成列计算值。
现在我们已经创建了带生成列的表,下面插入数据:
INSERT INTO Students (Id, FirstName, LastName)
VALUES (0001, 'Lucy', 'Green');
INSERT INTO Students (Id, FirstName, LastName)
VALUES (0002, 'Aziz', 'Ahmad');
INSERT INTO Students (Id, FirstName, LastName)
VALUES (0003, 'Zohan', 'Ahuja');
INSERT INTO Students (Id, FirstName, LastName)
VALUES (0004, 'Homer', 'Presley');
INSERT INTO Students (Id, FirstName, LastName)
VALUES (0005, 'Sally', 'Smith');
注意,我们插入数据不包括生成列,现在查看数据:
SELECT * FROM Students;
结果为:
id | firstname | lastname | fullname
----+-----------+----------+---------------
1 | Lucy | Green | Lucy Green
2 | Aziz | Ahmad | Aziz Ahmad
3 | Zohan | Ahuja | Zohan Ahuja
4 | Homer | Presley | Homer Presley
5 | Sally | Smith | Sally Smith
我们看到生成列包含FirstName和LastName两列值的连接串。生成列表达式不仅为字符串连接,举例:一些场景中需要基于原价和折扣计算实际价格。
生成列可以为 stored 或 virtual. 两者的差异为:
生成的列有许多限制。例如,生成表达式不能引用另一个生成的列。此外,它们只能使用不可变函数,不能以任何方式使用子查询或引用当前行以外的任何内容。具体包括:
到此这篇关于PostgreSQL生成列实现过程介绍的文章就介绍到这了,更多相关PostgreSQL生成列内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
--结束END--
本文标题: PostgreSQL生成列实现过程介绍
本文链接: https://www.lsjlt.com/news/177468.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-15
2024-05-14
2024-05-14
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0