gpt4 book ai didi

SQL 服务器 : create dynamically queries to select all related data in DB based on entry table and ID

转载 作者:搜寻专家 更新时间:2023-10-30 22:10:24 27 4
gpt4 key购买 nike

我的任务是创建一个 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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com