- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个这样定义的表:
create table users (
id serial primary key,
name text,
email text,
);
...我想编写一个返回形状行的函数:
(
id integer,
name text,
email text,
some_other_column boolean,
)
我设法通过下面的代码实现了这一点,但我不想重新定义用户表中的列:
create or replace function get_users ()
returns table (
id integer,
name text,
email text,
some_other_column boolean,
) as $$
select users.*, true as some_other_column from users;
$$ language sql;
有没有办法通过做这样的事情来动态创建行类型? (postgres 提示 users.*
的语法错误):
create or replace function get_users ()
returns table (
users.*,
some_other_column boolean
) as $$
select users.*, true as some_other_column from users;
$$ language sql;
请注意,直接执行以下查询工作正常:
select users.*, true as some_other_column from users;
这里的最终目标是最终得到一个可调用函数,如 select * from get_users()
返回的行包括现有表中的列和其他列。我不希望调用者担心究竟如何调用该函数。
我的假设是,由于我可以编写返回动态行的简单 sql,所以我应该能够以某种方式将该 sql 存储在数据库中,以保留返回行的结构。
最佳答案
否。目前没有办法做到这一点(包括第 10 页)。
SQL 是一种严格类型化的语言。创建函数时,必须声明返回类型。要返回一组行集(您可以使用 SELECT * FROM srf()
调用):
您可以返回匿名记录(RETURNS SETOF 记录
)。但是你必须在每次调用时提供一个列定义列表。
您可以返回多态(行)类型(RETURNS SETOF anyelement
)。但是您必须提供行类型 ( composite type ) 作为函数的参数,并且需要在系统中注册行类型以某种方式。
您可以使用 RETURNS SETOF
rowtype
显式使用任何已注册的行类型。副作用是函数现在取决于行类型。
您可以使用 RETURNS TABLE (...)
临时定义返回的行类型 - 您甚至可以混合行类型 (composite types) 和简单类型。但是一个简单的 SELECT * FROM srf()
不会分解嵌套的行类型——比如 Mabu's answer去演示。
相关:
这一切归结为:
Is there a way to dynamically create a row type by doing something like this?
不,没有。 SELECT * FROM ...
将从系统目录中检索列定义列表,其中行类型必须在 之前注册,您可以通过这种方式调用该函数。
通常最好在 RETURNS TABLE ()
子句中拼出列定义列表。这避免了依赖性。如果您需要快速注册基于现有表的行类型而不拼写其列,您可以创建一个 VIEW
- 或者一个 TEMPORARY VIEW
如果它只是用于当前 session :
CREATE TEMP VIEW v_users_plus AS
SELECT *, NULL::boolean AS some_other_column FROM users;
这会在系统中注册一个同名的行类型 (v_users_plus
),就像任何其他表或 View 一样。对于非临时函数,显然需要非临时行类型。
关于postgresql - 如何返回表的行类型加上函数的附加列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44791839/
我已经搜索了对此的一种解释,但没有找到一种解释。在Prolog谓词的描述中,有时在变量名之前的问号,加号和减号是什么意思? 例: predicate(?Variable1,+Variable2,-Va
我正在尝试使用以下脚本 $(document).ready(function() { $('#item1_number_1').keyup(function() {
在下面的代码片段中考虑用注释的等价物替换第 8 行 1. private static String ipToText(byte[] ip) { 2. StringBuffer result = n
对于要在图表中显色的级别数要多的因子,我想用“其他”替换不在“前10名”中的任何级别。 替代问题:如何将因子水平降低到rcolorbrewer可以绘制为单独颜色的数量? 例如,如果我想从棒球数据中绘制
我想要一个通过 ssh 进入机器的命令,运行一个命令(cd 或执行脚本或 su),然后给我 shell。向 ssh 传递命令似乎总是退出。 我正在寻找的一些例子: 'ssh me@machine1 "
我正在尝试将引导工具提示附加到特定的全日历日 View td 元素。我可以从该元素上的 FC 单击事件获取 td 元素。如果我执行 console.dir(thing); 那么该元素将作为一个对象返回
我有一个脚本,应该循环遍历一系列 csv 文件以创建不同的有向图。当使用 matplotlib (plt.savefig()) 保存时,随着循环的进行,图表似乎会被保存在另一个图表之上。如果我使用 p
每当我输入数据库时,我都会使用strip_tags函数,每当我输出信息时,我都会使用htmlspecialchars。也就是说,如果我向数据库中引入类似的内容: Hello, Mr. John.
我想在我的网站上实现触摸屏自动滚动。示例可以在 Ubuntu 和 Windows 8 的界面中看到。 Ubuntu: window 8: 如果您快速向下滚动页面,松手后它会继续滚动并逐渐变慢。如果滚动
我正在尝试了解 Java 中的并发性。我知道同步,它在对象上创建一个监视器,之后另一个线程无法对该对象进行操作。 Volatile - 与处理器缓存有关,如果我使用它,所有线程都不会创建对象的副本。所
我最近将我的应用程序从使用自定义 SplashScreen(它只是一个带有计时器的表单加载主表单并自行关闭)更改为应用程序框架。 这是我所做的: 创建了一个新的 SplashScreenForm,用于
我想通过使用Sqoop作为Parquet文件将数据从Oracle导入到Hive。 我一直在尝试使用sqoop使用以下命令导入数据: sqoop import --as-parquetfile --co
我有一些使用 SpringJUnit4ClassRunner 运行的测试。我也刚刚迁移到 Log4j2,现在加载 log4j2.xml 配置文件时遇到问题,我总是收到此错误: ERROR Status
在正则表达式方面不是很好,但为什么在找到匹配项时 console.log 会触发两次? $('#name').keyup(function() { var regex = /[\€]/g;
我已经了解了 Spring Integration 4.2.0.RELEASE 中的新功能,用于通过 @EnableIntegrationManagement 注释和 捕获 channel 和处理程序
因此,我正在尝试将 vector 与智能指针一起使用,以便更轻松地进行内存管理,而且...好吧,我遇到了问题。这是我的代码的(大大缩短的)版本: bulletManager.h: class Bull
我正在制作游戏,我希望敌人绕圈移动,但敌人也应该不断向左移动。我尝试使用 CGPath 创建一个圆形路径并使其遵循该路径,然后添加一个不断向左移动的 SKAction。但节点似乎只是沿着 CGPath
我想写一个函数tokenize这需要 char s 来自迭代器。像这样: fn tokenize>(file: F) 如果我想使用 &str有了这个功能,我可以这样做: tokenize("foo".
我不确定我的理解是否正确 int i = 5; float f = 3.9; int result = i + f; 那么当int和float相加时,8.9就变成了8?这是否意味着
我想对相册进行更新突变,但在获取更新和返回值时遇到问题。 架构 Mongoose : var AlbumSchema = new Schema({ name: String, date
我是一名优秀的程序员,十分优秀!