- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用全局应用程序用户帐户访问数据库 A。此用户帐户无权修改数据库 A 的架构(即创建表、修改表等)。该用户还可以访问数据库 B,但只能访问 View 。我需要运行 SQL 将数据从数据库 B 中的 View 提供到数据库 A 中的表中。
在一个完美的世界中,我将能够使用这个 SQL:create database_a.mytable as (select * from database_b) with no data
但是,用户无法在数据库 A 中创建表。 如果我可以获取 select 语句的 DDL,那么我可以在我的个人帐户下登录(该帐户对数据库 B 没有任何访问权限)并在数据库中运行 DDL A 创建表。
唯一的另一种选择是手动编写 SQL,但我不想这样做,尤其是因为我要复制的这个 View 具有许多不同数据类型和大小的列。
编辑:我可能越来越近了。我刚刚尝试了这个:show (select * from database_b.myview)
但是,它生成了 View 本身中使用的每个表的 DLL,以及 View 的定义。这并没有真正帮助我,因为我只想要 select 语句本身的模式。换句话说,如果我要使用 create table as
,我需要生成什么。上面提到的声明。
为 Rob 编辑:也许“DDL”是错误的使用术语。使用 show view db.myview
只显示 View 的定义,而不是它代表的模式。在我上面的 create table as
示例中,我将展示如何创建一个表来模拟选择中返回的结果集的架构。它在后端生成一个用于创建表的 DDL,然后执行该 DDL 以实际创建表。然后你可以说 show table db.newtable
并查看新表的 DDL。我想直接从 select 语句中获取该 DDL,以便我可以复制它,注销应用程序帐户,进入我的个人帐户,然后执行 DDL 以创建表。
这只是为了避免我不得不手动输入 DDL 以节省时间并减少输入错误的麻烦,特别是因为源 View 有这么多列。也就是说,我认为联系 DBA 或编写一些时髦的存储过程来执行动态操作对于我的需求来说有点过头了。我认为必须有一种方法可以直接从 select 语句中获取用于创建表模式的 DDL。
最佳答案
为对象生成 DDL 语句:
SHOW TABLE {DatabaseB}.{Table1};
SHOW VIEW {DatabaseB}.{View1};
HELP VIEW {DatabaseB}.{View1};
DatabaseA
你没有太多的筹码。显然,如果对象已经存在
INSERT INTO SELECT ... FROM DatabaseB.Table1
或
MERGE INTO
将是您已经探索过的选项。
CREATE VOLATILE TABLE {Global Application UserID}.{TableA_Copy} AS
(
SELECT *
FROM {DatabaseB}.{TableA}
)
WITH NO DATA
NO PRIMARY INDEX
ON COMMIT PRESERVE ROWS;
SHOW TABLE {Global Application UserID}.{TableA_Copy};
NO PRIMARY INDEX
的 Teradata 13.10 功能.默认情况下,
CREATE TABLE
AS 将取
SELECT
的第一列声明并将其设为
PRIMARY INDEX
表的。这可能会导致测试中出现倾斜和永久空间问题,具体取决于数据人口统计。您可以指定显式
PRIMARY INDEX
当您了解基础数据时,请自行决定。 (如果不确定,请参阅 DDL 手册以获取有关语法的详细信息。)
ON COMMIT PRESERVE ROWS
的使用对于这个例子的意图可能是无关紧要的。但实际上,如果您将任何数据弹出到该表中以测试此子句在 Teradata 模式下将是有益的,否则数据将在
CREATE TABLE
之后立即丢失。或对 volatile 表执行任何其他数据操作。
关于Teradata:有没有办法从 View 或选择语句生成 DDL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12915067/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!