SQL Server在用户自定义函数中UDF使用临时表,这是不允许的. 有时是为了某些特殊的场景, 我们可以这样的实现:

CREATE TABLE #temp (id INT)
GO
INSERT INTO #temp VALUES (1),(2),(3)
GO
CREATE SYNONYM temp_table_synonym FOR #temp
GO
CREATE FUNCTION fn_select_temp_table ()
RETURNS TABLE
AS
RETURN
(
 SELECT * FROM temp_table_synonym
)
GO
SELECT * FROM fn_select_temp_table()
GO

我们使用了SYNONYM,这是关键之处. 但实际过程中是不推荐这种做法. 这也可能是SQL SERVER另一个BUG.

希望对您开发有帮助.

Petter Liu Blog。

相关文章:

  • 2021-09-06
  • 2022-02-20
  • 2022-12-23
  • 2021-08-18
  • 2021-11-01
  • 2022-01-14
  • 2021-11-12
  • 2023-02-01
猜你喜欢
  • 2021-09-14
  • 2022-03-02
  • 2021-12-26
相关资源
相似解决方案