- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我的任务是创建一个 SQL 语句,该语句将创建(并运行?)多个其他查询,这些查询将选择从给定 ID (uniqueidentifier) 和给定表名传出的所有相关数据。
它不必那么快,但它应该能够针对每个数据库使用,只需给定 1 个 ID 和表名。
在数据库中,有一些 1:n、n:m 等关系,并不是每个表都有一个名为 Id 的列,有些只有外键,它必须是完全动态和通用的。
我试图自己实现它,但我的 SQL 不太好,我还尝试了一些其他脚本,这些脚本将返回主外键关系,但我被困在那里,所以我以为你伙计们可能会帮助我:)
要返回,我需要(最好)生成查询,我可以针对数据库运行这些查询并返回所有信息(是否有其他好的返回可能性?)
或者,我可以用 C# 创建这个项目,但我也一直在尝试。
我会很感激任何形式的帮助:)
最佳答案
以下将生成一组查询,然后可以将其粘贴到 ssms 中并执行。
您需要指定您感兴趣的表、列和 id 值。
另请注意,这可能需要进行调整以使用模式等,并且您可以执行使用游标返回的 SQL 我相信,但我认为这会让您走上正确的轨道:
DECLARE @idvalue int = 1
DECLARE @colName nvarchar(max) = 'myid'
DECLARE @tableName nvarchar(max) = 'Table_1'
DECLARE @tmp_Accounts TABLE (
PKTABLE_QUALIFIER sysname
,PKTABLE_OWNER sysname
,PKTABLE_NAME sysname
,PKCOLUMN_NAME sysname
,FKTABLE_QUALIFIER sysname
,FKTABLE_OWNER sysname
,FKTABLE_NAME sysname
,FKCOLUMN_NAME sysname
,KEY_SEQ smallint
,UPDATE_RULE smallint
,DELETE_RULE smallint
,FK_NAME nvarchar(max)
,PK_NAME nvarchar(max)
,deferrability smallint
)
insert into @tmp_Accounts exec sp_fkeys @tableName
select
'select * from ['+FKTABLE_NAME+'] where ['+FKCOLUMN_NAME+'] = '
+ cast(@idvalue as nvarchar(max))
from
@tmp_Accounts
where
PKCOLUMN_NAME = @colName
另请注意,您需要根据所选 ID 调整数据类型。
例如
SQLFiddle - 获取要执行的查询: http://sqlfiddle.com/#!3/fbf40/1
SQLFiddle - 执行返回的查询: http://sqlfiddle.com/#!3/fbf40/2
关于SQL 服务器 : create dynamically queries to select all related data in DB based on entry table and ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31676494/
Eclipse 提示此代码“类型参数 Entry 隐藏了类型 Map.Entry”: import java.util.Map.Entry; public class Test { stat
这两个for语句是等价的。 import java.util.Map; import java.util.Map.Entry; for (Map.Entry entry: map.entrySet()
我想在 python 字典中添加一个键/值,它依赖于现有的键/值。示例 x = {} x["length"] = 12 x["volume"] =x["lenght"] * 10 行得通;但是有没有可
我使用 NuGet 将我的 EntityModel 升级到版本 4.3。 现在我想更改我的 EntityObject.State,但找不到 .Entry() 方法。 当前状态是已删除。 这就是我想要做
我是 Java 新手,正在使用 HashMap 在 Mac 上编写 Java。 但是我遇到了一个问题,找不到答案 import java.util.Map; import java.util.Hash
我正在切换一个小应用程序(Win 7/64 上的 Python 2.7.3/32)来使用 ttk,但我在使 ttk.Entry 按照 tk.Entry 的方式工作时遇到问题;当我设置其内容时,ttk.
为什么我需要在 i.next(); 前面加上 (Map.Entry) ?为什么我不能只有 Map.Entry m = i.next();? 对不起。它是一个 HashMap。 最佳答案 因为它显然不是
我的 xPage SSJS 失败: viewEntry = view.getNext(viewEntry); 有错误 Notes error: Entry not found in index 我确实
我正在使用 DataTable在我的申请中。 我想隐藏左下角的细节,我该怎么做? “显示 1,657 个条目中的 1 到 10 个(从 9,044 个条目中筛选出来)” 这是我的设置: $('#inv
我有两列,一个时间戳和一个已选择卡片的数字。 card added 1 2016-09-23 13:48:48 3 2016-09-23 13:48:48 1
我正在使用 Entity Framework 4.1,并且我有我的 DbContext Override SaveChanges 来审核属性更改。从“GetEntryValueInString”返回空
我正在使用 Tkinter 在 Python 3 上编写 GUI,但每次使用 Entry() 时,我都会收到名称错误。 我尝试了一个更简单的代码版本,(写在下面),但它仍然导致了 NameError:
我刚刚创建了一个插入方法来对数组进行排序,这是我在该方法中完成的代码; public static void insertionSort (Entry[] array2){ for (int
使用这个例子1对于 n:n 关系: (来源:tekstenuitleg.net) 设置主要或主要多对多字段的最佳方法是什么?示例:假设我想将经销商“Devrolijke drinker”(ID AB9
是否可以使用 Entry 通过 AsRef 获取值的 API , 但用 Into 插入它? 这是工作示例: use std::collections::hash_map::{Entry, HashMa
是否可以使用 Entry 通过 AsRef 获取值的 API , 但用 Into 插入它? 这是工作示例: use std::collections::hash_map::{Entry, HashMa
是否可以使用 Entry 通过 AsRef 获取值的 API , 但用 Into 插入它? 这是工作示例: use std::collections::hash_map::{Entry, HashMa
表定义: CREATE TABLE PositionalDataNGS ( Date DATE, Time TIME(3) , X FLOAT(5), Y FLOAT(5), D FLOAT(5) ,
我的平台: PHP 和 MySQL 我这里有什么: 我有 4 个表,分别是“books”、“book_type”、“book_categories”、“all_categories”。 我想做什么:
I am using MySQL 5.1.56, MyISAM. My table looks like this:我使用的是MySQL 5.1.56,MyISAM。我的桌子是这样的: CR
我是一名优秀的程序员,十分优秀!