在创建临时表并像这样声明数据类型之后;
CREATE TABLE #TempTable(
ID int,
Date datetime,
Name char(20))
然后,我如何插入已经在数据库中的物理表上持有的相关数据?
在创建临时表并像这样声明数据类型之后;
CREATE TABLE #TempTable(
ID int,
Date datetime,
Name char(20))
然后,我如何插入已经在数据库中的物理表上持有的相关数据?
当前回答
INSERT INTO #TempTable (ID, Date, Name)
SELECT id, date, name
FROM physical_table
其他回答
insert into #temptable (col1, col2, col3)
select col1, col2, col3 from othertable
注意,这被认为是糟糕的做法:
insert into #temptable
select col1, col2, col3 from othertable
如果临时表的定义要更改,则代码可能在运行时失败。
正确的查询:
drop table #tmp_table
select new_acc_no, count(new_acc_no) as count1
into #tmp_table
from table
where unit_id = '0007'
group by unit_id, new_acc_no
having count(new_acc_no) > 1
INSERT INTO #TempTable (ID, Date, Name)
SELECT id, date, name
FROM physical_table
要插入所有列中的所有数据,只需使用以下命令:
SELECT * INTO #TempTable
FROM OriginalTable
不要忘记在你完成临时表之后,在你尝试再次创建它之前,DROP它:
DROP TABLE #TempTable
临时表的基本操作如下,请根据您的要求修改和使用,
——创建临时表
CREATE TABLE #MyTempEmployeeTable(tempUserID varchar(MAX), tempUserName varchar(MAX) )
——向临时表中插入值
INSERT INTO #MyTempEmployeeTable(tempUserID,tempUserName) SELECT userid,username FROM users where userid =21
查询一个临时表[这将只在同一个会话/实例中工作,而不是在其他用户会话实例中]
SELECT * FROM #MyTempEmployeeTable
——删除temp表中的值
DELETE FROM #MyTempEmployeeTable
——删除一个临时表
DROP TABLE #MyTempEmployeeTable