如果目标表已经存在,我希望查询将记录从一个表插入到另一个表中的另一个表中,它应该将记录附加到表的末尾。
答案 0 :(得分:120)
这个怎么样:
USE TargetDatabase
GO
INSERT INTO dbo.TargetTable(field1, field2, field3)
SELECT field1, field2, field3
FROM SourceDatabase.dbo.SourceTable
WHERE (some condition)
答案 1 :(得分:26)
如何将表值从一个服务器/数据库插入另一个数据库?
1创建链接服务器{if needs}(SQL server 2008 R2 - 2012) http://technet.microsoft.com/en-us/library/ff772782.aspx#SSMSProcedure
2配置链接服务器以使用凭据 a)http://technet.microsoft.com/es-es/library/ms189811(v=sql.105).aspx
EXEC sp_addlinkedsrvlogin 'NAMEOFLINKEDSERVER', 'false', null, 'REMOTEUSERNAME', 'REMOTEUSERPASSWORD'
- 检查服务器
SELECT * FROM sys.servers
- 测试链接服务器
EXEC sp_testlinkedserver N'NAMEOFLINKEDSERVER'
插入新的本地表
SELECT * INTO NEWTABLE
FROM [LINKEDSERVER\INSTANCE].remoteDATABASE.remoteSCHEMA.remoteTABLE
OR
在远程表中插入新值
INSERT
INTO [LINKEDSERVER\INSTANCE].remoteDATABASE.remoteSCHEMA.remoteTABLE
SELECT *
FROM localTABLE
插入新的本地表值
INSERT
INTO localTABLE
SELECT *
FROM [LINKEDSERVER\INSTANCE].remoteDATABASE.remoteSCHEMA.remoteTABLE
答案 2 :(得分:9)
这是一种快速简便的方法:
$book_name = [];
array_walk_recursive($arr, function($v, $k)use(&$book_name) {
if ($k == 'book_name') {
$book_name[$v] = (strpos($v,"Bible") !== false) ? "Found" : "God not found";
}
});
print_r($book_name);
答案 3 :(得分:6)
你可以尝试
Insert into your_table_in_db1 select * from your_table_in_db2@db2SID
db2SID是其他数据库的sid。它将出现在tnsnames.ora文件中
答案 4 :(得分:6)
--Code for same server
USE [mydb1]
GO
INSERT INTO dbo.mytable1 (
column1
,column2
,column3
,column4
)
SELECT column1
,column2
,column3
,column4
FROM [mydb2].dbo.mytable2 --WHERE any condition
/*
steps-
1- [mydb1] means our opend connection database
2- mytable1 the table in mydb1 database where we want insert record
3- mydb2 another database.
4- mytable2 is database table where u fetch record from it.
*/
--Code for different server
USE [mydb1]
SELECT *
INTO mytable1
FROM OPENDATASOURCE (
'SQLNCLI'
,'Data Source=XXX.XX.XX.XXX;Initial Catalog=mydb2;User ID=XXX;Password=XXXX'
).[mydb2].dbo.mytable2
/* steps -
1- [mydb1] means our opend connection database
2- mytable1 means create copy table in mydb1 database where we want
insert record
3- XXX.XX.XX.XXX - another server name.
4- mydb2 another server database.
5- write User id and Password of another server credential
6- mytable2 is another server table where u fetch record from it. */
答案 5 :(得分:1)
INSERT
INTO remotedblink.remotedatabase.remoteschema.remotetable
SELECT *
FROM mytable
在关系数据库中没有“表的末尾”这样的东西。
答案 6 :(得分:0)
如果两个表具有相同的架构,则使用以下查询: 插入database_name.table_name中,从new_database_name.new_table_name中选择*,其中='condition'
用第一个数据库的名称替换database_name,并用要复制的表的名称替换table_name 还将new_database_name替换为您要复制的其他数据库的名称,而new_table_name是表的名称。
答案 7 :(得分:0)
就做.....
(它将创建与from table到具有相同数据的table相同的table结构)
create table toDatabaseName.toTableName as select * from fromDatabaseName.fromTableName;
答案 8 :(得分:0)
对于SQL Server,您可以使用工具“从另一个数据库导入数据”,配置映射列更容易。
答案 9 :(得分:0)
大多数情况下,我们需要在迁移脚本中使用这种类型的查询
INSERT INTO db1.table1(col1,col2,col3,col4)
SELECT col5,col6,col7,col8
FROM db1.table2
在此查询中,两个表中的列数必须相同