- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
是否可以定义在默认情况下创建新表的模式? (由“不合格的表名”引用。)
我看过一些关于在 Postgres 中使用“搜索路径”的细节,但我认为它只在检索数据时有效,而不是在创建数据时有效。
我有一堆 SQL 脚本,可以创建很多表。我不想修改脚本,而是希望默认情况下在特定模式中设置数据库创建表 - 当它们具有不合格的名称时。
这可能吗?
最佳答案
search_path
是什么?[...] tables are often referred to by unqualified names, which consistof just the table name. The system determines which table is meant byfollowing a search path, which is a list of schemas to look in.
大胆强调我的。这解释了标识符解析。
“当前模式”(或“默认模式”)是,per documentation:
The first schema named in the search path is called the currentschema. Aside from being the first schema searched, it is also theschema in which new tables will be created if the
CREATE TABLE
commanddoes not specify a schema name.
大胆强调我的。系统架构 pg_temp
(当前 session 的临时对象架构)和 pg_catalog
自动成为搜索的一部分路径并按此顺序首先搜索。 The manual:
pg_catalog
is always effectively part of the search path. If it is notnamed explicitly in the path then it is implicitly searched beforesearching the path's schemas. This ensures that built-in names willalways be findable. However, you can explicitly placepg_catalog
atthe end of your search path if you prefer to have user-defined namesoverride built-in names.
按照原文大胆强调。 pg_temp
出现在它之前,除非它被放在不同的位置。
有多种方法可以设置运行时变量search_path
.
为 postgresql.conf
中的所有数据库中的所有角色设置一个集群范围内的默认值(并重新加载)。小心!
search_path = 'blarg,public'
factory default for this setting是:
search_path = "$user",public
The first element specifies that a schema with the same name as thecurrent user is to be searched. If no such schema exists, the entry is ignored.
和:
If one of the list items is the special name
$user
, then the schemahaving the name returned byCURRENT_USER
is substituted, if there issuch a schema and the user hasUSAGE
permission for it. (If not,$user
is ignored.)
将其设置为一个数据库的默认值:
ALTER DATABASE test SET search_path = blarg,public;
将其设置为您连接的角色的默认值(在整个集群范围内有效):
ALTER ROLE foo SET search_path = blarg,public;
或者甚至(通常是最好的!)作为数据库中角色的默认值:
ALTER ROLE foo IN DATABASE test SET search_path = blarg,public;
将命令写在脚本的顶部。或者在您的数据库 session 中执行它:
SET search_path = blarg,public;
为函数范围设置特定的search_path
(以防止具有足够权限的恶意用户)。了解 Writing SECURITY DEFINER
Functions Safely在手册中。
CREATE FUNCTION foo() RETURNS void LANGUAGE plpgsql SECURITY DEFINER SET search_path=blarg,public,pg_temp AS$func$BEGIN -- do stuffEND$func$;
Higher number in the list trumps lower number.
The manual has even more ways, like setting environment variables or using command-line options.
To see the current setting:
SHOW search_path;
收件人reset它:
RESET search_path;
The default value is defined as the value that the parameter wouldhave had, if no
SET
had ever been issued for it in the current session.
关于postgresql - search_path 如何影响标识符解析和 "current schema",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9067335/
这是一个非常笼统的问题,我希望我能答对。 我正在研究 SSL/TLS 重新协商并已阅读了一些内容。这是我从阅读中了解到的内容: 从 SSL/TLS 重新协商的角度来看,客户端分为两个主要组,打补丁的和
第一个屏幕是艺术的细节。当我向上滚动时,标题将是 alpha。我点击另一个“艺术”到另一个细节 UI,然后按回到 Previous UI。之前的UI标题是黑色的,怎么变透明了。 布局:
想知道 mv 对基表的影响。它会减慢基表的速度吗?它什么时候开始写入 mv,就像同时写入基表和 mv 一样? 如果我有 local_quorum 的 CL 且 RF=3,客户端是否必须等到写入 mv
似乎在任何地方都找不到太多关于此问题的帮助,所以我想我会在这里尝试。 我正在尝试制作一个简单的 for 循环,当我将鼠标悬停在 html 卡上时,它会隐藏卡中的一些文本。该卡有一个简单的名字和姓氏,我
我有一个程序每帧运行 tick() 方法。我希望一个对象根据设定的重力常数下落,因此我创建了一个 Ball 对象,该对象会将其位置更新为前一帧的位置减去 y 速度。每个刻度 y 速度都会减少重力常数。
我的 KeyHandler 在这里: private void KeyHandler(java.awt.event.KeyEvent evt) {
我有一个方法,其中使用了很多其他类,包括链接列表、队列和堆栈。在我的方法中,我有一个 for 循环,我想在其中弹出堆栈(方便地命名为 s)并将队列(方便地命名为 q)出队到 s1 和 q1。由于某种原
我有一个 JTree 节点数组和另一个自定义对象的相应数组。 我想要什么:当选择 JTree 的节点时,相应对象(其数组中索引与节点数组中所选节点索引相同的对象)的字段填充 JLabels。 我被困在
我知道浏览器完成了处理客户端脚本(Javascript、JQuery 等)的所有工作,但想知道在性能方面是否还有其他重要因素(网络速度、客户端计算机速度、服务器环境) 如果它完全依赖于浏览器(类型和版
我有一个 Android 服务在后台运行,它将使用以下代码: while(true) { ServerSocket server = new ServerSocket(1234); Socke
对JQM有以下疑惑: 1.如果我们在单独的 html 文件中使用重复的 id,对 jquery mobile 有什么影响。 假设我们在单独的 html 文件中有重复的 id,但如果我们不使用该 id
我正在尝试更新两个(inventory、sold)MySQL 表的表库存。 假设我们正在处理的 sku 是 BT888-16 UPDATE inventory JOIN sold ON invento
我使用这种方法来更改我的表格单元格值, 它在 jtable 上改变但在文本文件上没有改变! public class user_AllBooks extends AbstractTableModel
我想在向表中插入数据时创建一个 MYSQL 存储过程,数据也会被插入到其他服务器表中。 我知道这在 ORACLE 数据库中是可能的,但我不知道它是否适用于 MYSQL。 有什么办法吗? 最佳答案 是的
我在 css 方面非常糟糕,只能靠 SO 答案来解决 - 但是我找不到针对这个特定问题的任何解释。 我有一个表单,其中包含一个 textarea 和一个 button(input/submit),仅此
我在一个元素上有动画,但它的移动也会影响 sibling 。如何在不影响兄弟元素的情况下仅在元素上使用动画? 问题示例: function animateSearch() { $('.glyph
我试图在我的 ViewController 中的 UIView 的所有四个边上建立一个阴影 — 在我通过 Xcode 向 UIView 添加约束之前,它工作得很好。我怎样才能使 UIView 的阴影显
自从我使用 JavaScript 以来已经有一段时间了 - 在获得证书之后我开始学习 Perl 并从那时起就一直使用它。我只是想重新开始使用 JS,我已经写了这个,我想说的是,这是一个简单的小脚本,可
我正在处理一个 HTML 元素,我添加了一个复选框,选中后会高亮显示所有文本输入字段。唯一的问题是一些输入字段在表格内,出于某种原因我无法用我的代码影响它们。任何帮助将不胜感激。 相关代码: HTML
我为 String 类创建了一个小扩展,以便方便地从中删除字符。这是它的样子: mutating func drop(characters chars: [String]) { for c i
我是一名优秀的程序员,十分优秀!