㈠ SQL SERVER 資料庫 怎麼從一個伺服器一個表中把數據插入到另一個伺服器中的一個表內
樓主您好您的意思實際上是SQLserver的分布式查詢:如果一個項目需要二至多台伺服器,而我們又必須從幾台伺服器中將數據取出來,這就必須用分布式查詢!
在這里有兩個概念:本地數據源、遠程數據源!
本地數據源指的是單個伺服器上的數據而遠程數據源指的是另一個SQL實例上的數據。
如何跨伺服器取數呢?
一、
如果經常訪問或數據量大,建議用鏈接伺服器--創建鏈接伺服器
exec sp_addlinkedserver ''srv_lnk'','''',''SQLOLEDB'',''遠程伺服器名或ip地址''
exec sp_addlinkedsrvlogin ''srv_lnk'',''false'',null,''用戶名'',''密碼''go
--查詢示例:
select * from srv_lnk.資料庫名.dbo.表名
--導入示例:
select * into 表 from srv_lnk.資料庫名.dbo.表名go--以後不再使用時刪除鏈接伺服器
exec sp_dropserver ''srv_lnk'',''droplogins''
二、
--如果只是臨時訪問,可以直接用openrowset
--查詢示例:
select * from openrowset(''SQLOLEDB'',''sql伺服器名'';''用戶名'';''密碼'',資料庫名.dbo.表名)
--導入示例:
select * into 表 from openrowset(''SQLOLEDB'',''sql伺服器名'';''用戶名'';''密碼'',資料庫名.dbo.表名)
如何在企業管理器中設置呢?
SQL實例--->安全性--->鏈接伺服器--->右鍵新建鏈接伺服器常規中輸入鏈接伺服器的名字,選其祥耐它數據源,選SQLOLEDB,數據源寫上,一般寫IP地址再選安全性-----》選本地登陸----》模擬打勾用此安全上下文進行,輸入用戶與密碼。
常見問題:1.在建立完鏈接伺服器後,我們進行查詢操作例:我們已對DFLD的伺服器做了鏈接,緊接著我們想訪問它中PUBS資料庫中的Authors表Select * From DFLD.PUBS..Authors經常會出二類問題
1.提示 異類查詢要求為連接設置 ANSI_NULLS 和 ANSI_WARNINGS 選項。這將確保一致的查詢語義。請啟用這 些選項,然後重新發出查詢。 這種提示是因謹拆春為沒有將ANSI_NULLS與ANSI_WARNINGS打開 SET ANSI_NULLS ON SET ANSI_WARNINGS ON Select * From DFLD.PUBS..Authors--這樣就可以了!
2.提示 某機器MSDTC服務不可用 這種提示很簡單,只需要御攜將MSDTC服務打開就是了!註:需要雙方均打開MSDTC服務,默認不打開
㈡ pl/sql如何在雲端伺服器上新建資料庫
oracle
新建資料庫跟sql
server等不一樣,不能直接新建,其新建資料庫的流程如下:
1、先建一個表空間
2、再新建一個新的用戶,管理這個表空間
3、賦予新用戶管理表空間的許可權
在本地伺服器上新建資料庫代碼如下:
--
先建表空間create
tablespace
mianyang_tbs
datafile
'E:\oracle\mianyang.dbf'
size
100M;--
新建用戶create
user
mianyang
identified
by
mianyang
default
tablespace
mianyang_tbs;--
賦予用戶許可權grant
connect,resource
to
mianyang;grant
dba
to
mianyang;
表空間數據的存儲位置在
E:\oracle\mianyang.dbf;
在雲伺服器上新建資料庫只需將表空間數據儲存位置改用對應的ip地址取代即可,具體代碼如下:
--
先建表空間create
tablespace
mianyang_tbs
datafile
'149.178.10.104:\mianyang.dbf'
size
100M;--
新建用戶create
user
mianyang
identified
by
mianyang
default
tablespace
mianyang_tbs;--
賦予用戶許可權grant
connect,resource
to
mianyang;grant
dba
to
mianyang;
㈢ 如何在雲伺服器中安裝資料庫
1、進入實例,點擊管理,選擇本實隱舉例安全組;
2、點擊配置規則,添加3306遠程連接埠安全規則;
正攜睜3、登錄WDCP,點擊安全管理,防火牆設置,點擊快速添加,添加遠程連接埠;
4、在WDCP後台,點擊phpmyadmin進入資料庫,然後點擊用戶,點相應資料庫表的編輯許可權;
5、在登錄信息這里,選擇任意主機,舉歲然後後面寫上資料庫的公網IP。
㈣ SQL Server中 兩個不同的資料庫中的兩張表如何關聯
1、首先就是創建幾個沒有任何關系的表,但是注意,你在將要作為外鍵表的表上必須使用與將要作為主鍵表的數據類型相同。
㈤ 微軟雲伺服器mysql資料庫怎麼建表中數據
方法/步驟滑侍 1、剛剛接觸mysql數據的人,第一步新建信豎吵資料庫,可打開phpmyadmin; 2、然後選擇資料庫菜單; 3、點擊sql菜單; 4、在輸入框中輸入下面語句 create database 資料庫名; 最後點執行,新資料庫就纖灶建好了。
㈥ sql server如何把一個表中所有數據插入另一台計算機的一個表
不同液握伺服器資料庫之間的數據操作
--創建鏈接伺服器
exec sp_addlinkedserver 'ITSV ', ' ', 'SQLOLEDB ', '遠程明鋒伺服器名或ip地址 '
exec sp_addlinkedsrvlogin 'ITSV ', 'false ',null, '用戶名 '激埋晌, '密碼 '
--查詢示例
select * from ITSV.資料庫名.dbo.表名
--導入示例
select * into 表 from ITSV.資料庫名.dbo.表名
--以後不再使用時刪除鏈接伺服器
exec sp_dropserver 'ITSV ', 'droplogins '
--連接遠程/區域網數據(openrowset/openquery/opendatasource)
--1、openrowset
--查詢示例
select * from openrowset( 'SQLOLEDB ', 'sql伺服器名 '; '用戶名 '; '密碼 ',資料庫名.dbo.表名)
--生成本地表
select * into 表 from openrowset( 'SQLOLEDB ', 'sql伺服器名 '; '用戶名 '; '密碼 ',資料庫名.dbo.表名)
--把本地表導入遠程表
insert openrowset( 'SQLOLEDB ', 'sql伺服器名 '; '用戶名 '; '密碼 ',資料庫名.dbo.表名)
select *from 本地表
--更新本地表
update b
set b.列A=a.列A
from openrowset( 'SQLOLEDB ', 'sql伺服器名 '; '用戶名 '; '密碼 ',資料庫名.dbo.表名)as a inner join 本地表 b
on a.column1=b.column1
--openquery用法需要創建一個連接
--首先創建一個連接創建鏈接伺服器
exec sp_addlinkedserver 'ITSV ', ' ', 'SQLOLEDB ', '遠程伺服器名或ip地址 '
--查詢
select *
FROM openquery(ITSV, 'SELECT * FROM 資料庫.dbo.表名 ')
--把本地表導入遠程表
insert openquery(ITSV, 'SELECT * FROM 資料庫.dbo.表名 ')
select * from 本地表
--更新本地表
update b
set b.列B=a.列B
FROM openquery(ITSV, 'SELECT * FROM 資料庫.dbo.表名 ') as a
inner join 本地表 b on a.列A=b.列A
--3、opendatasource/openrowset
SELECT *
FROM opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陸名;Password=密碼 ' ).test.dbo.roy_ta
--把本地表導入遠程表
insert opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登陸名;Password=密碼 ').資料庫.dbo.表名
select * from 本地表
㈦ insert 同時向兩個表插入數據
用存儲過程吧
create proc 存儲過程名
@ItemId nchar(20),
@ItemName nchar(200),
@ItenType nchar(20),
@ItemCharge double
as
insert into A value (@ItemId,@ItemName,@ItemType)
insert into A value (@ItemId,@ItemName,@ItemType,@ItemCharge)
GO
================================================
也不是說一帆塵定要到伺服器首轎襪端才能實現這樣的功能~~
如果在客戶端想實現這樣的功能,可能需要寫者激兩個方法了
就是在點擊按鈕的時候,執行兩次插入命令~
這樣對系統性能會打折扣的.....
㈧ 如何向SQL資料庫兩個表同時添加數據
推薦是用存儲過程加事務實現.或直接在asp里寫加上事務就可以同時的插入了.如果中間出錯的話還能回滾,可保持數據的一致性.去上搜索一下事務等的相關資料很多的.
在開發Web應用時,無一例外地需要訪問資料庫,以完成對數據的查詢、插入、更新、刪除等操作。受應用邏輯的影響,有時需要將多條資料庫操作指令組成一個工作單元(事務)。在資料庫中,殲告枯所謂事務是指一組邏輯操作單元,它使數據從一種狀態變換到另一種狀態。為確保資料庫中數據的一致性,應當用離散的成組的邏輯單元操作數據:當它全部完成時,數據的一致性可以保持;而當單元中的一部分操作失敗時,整個事務會被全部忽略,所有從起始點以後的操作全部退回到開始狀態。
實際上,在默認方式下對資料庫的每一次操作都是隱含的事務處理。本文以一個典型的用戶注冊程序為例,介紹三種利用ASP實現事務處理的方法:基於ASP資料庫組件的解決方法、基於資料庫內部的事務處理機制的解決方法和基於MTS組件的解決方法。
程序功能
在SQL Server資料庫中建立兩個表:USER表和USERDOC表。其中USER表中存放的是注冊用戶的用戶名和密碼,USERDOC表中存放的是該注冊用戶的個人資料,並且以用戶名為索引。下面是表USER和USERDOC的定義:
Create Table USER(userName varchar(30),userPasswd varchar(30))
Create Table USERDOC(userName varchar(30),Age int,Sex int,PhoneNumber varchar(20),Address varchar(50))
當用戶請求注冊時,ASP腳本先將用戶名和密碼插入到USER表中,然後在USERDOC表中插入用戶個人信息(年齡、性別、聯系電話和家庭住址等)。同時,應用程友毀序還必須保證USER表中的每一條記錄在USERDOC表中都有相應的記錄。
方法一
利用ASP內置ADO組件中的Connection對象可以實現對資料庫操作的事務性處理。Connection對象的部分方法如下:
●Connection.BeginTrans方法:啟動一個事務;
●Connection.CommitTrans方法:完成/提交一個事務;
●Connection.RollBackTrans方法:撤消/放棄一個事務。
//啟動一個事務操作
<% Conn.BeginTrans %>
<% sqlText=「Insert into USER(userName,userPasswd) values(『」 %>
<% sqlText=sqlText & request(「usrName」) & 「』,『」&request(「usrPasswd」)&「』) 」 %>
<% conn.execute(sqlText) %>
<% if conn.Errors.Count>0 then %>
<% conn.Errors.Clear %>
//如果插入數據操作失敗,則事務向氏洞前回滾
<% conn.RollBackTrans %>
<% response.Redirct RegisterFail.html %>
<% end if %>
<% sqlText=「Insert into USERDOC(userName,Age,Sex,PhoneNumber,Address) 」%>
<% sqlText=sqlText & 「values(『」& request
(「usrName」) & 「』, 」 & request(「Age」) %>
<% sqlText=sqlText & 「,『」 & request
(「PhoneNum」) & 「』,『」 %>
<% sqlText=sqlText & request(「Address」) & 「』) 」 %>
//執行事務單元中的第二條插入語句
<% conn.execute(sqlText) %>
<% if conn.Errors.Count>0 then %>
<% conn.Errors.Clear %>
//如果操作失敗,則事務向前回滾
<% conn.RollBackTrans %>
<% response.Redirct RegisterFail.html %>
<% end if %>
//如果整個事務操作執行正確,則提交事務
<% Conn.CommitTrans %>
//轉向注冊成功處理頁面
<% response.Redirct RegisterOk.html %>
方法二
可以利用資料庫系統內部的事務處理機制,通過在資料庫伺服器中編寫包含事務的存儲過程,完成對數據操作的事務處理。同時,利用ADO組件調用存儲過程,還可以根據存儲過程的返回代碼判斷事務處理是否執行成功。
在資料庫系統中,每一條SQL語句都是一個事務。因此可以保證每條語句要麼完成,要麼退回到開始之處。但是如果希望一組SQL語句的操作要麼全部完成,要麼全部無效,就需要利用資料庫的事務處理機制來實現。
在資料庫中生成存儲過程的主要代碼如下:
Create proc RegisterUser
(@usrName varchar(30), @usrPasswd varchar(30),@age int, @PhoneNum varchar(20), @Address varchar(50) )
as
begin
//顯示定義並開始一個事務
begin tran
insert into USER(userName,userPasswd) values(@usrName,@usrPasswd)
if @@error<>0
begin
//操作失敗,則事務回滾
rollback tran
//返回存儲過程,並設置返回碼為事務操作失敗
return -1
end
insert into USERDOC(userName,age,sex,PhoneNumber,Address)
values(@Usrname,@age,@PhoneNum,@Address)
if @@error<>0
begin
//操作失敗,則事務回滾
rollback tran
return -1
end
//如果操作執行正確,則提交事務
commit tran
return 0
end
在ASP腳本中調用資料庫存儲過程的主要代碼如下:
<% Set Comm=server.CreateObject
(「ADODB.Command」) %>
<% Set Comm.ActiveConnection=conn %>
<% Comm.CommandType=adCmdStoredProc %>
<% Comm.CommandText=「RegisterUser」 %>
//創建存儲過程返回參數對象
<% Set RetCode=Comm.CreateParameter
(「RetCode」,adInteger,adParamReturnValue) %>
//創建存儲過程輸入參數對象
<% Set usrName=Comm.CreateParameter
(「usrName」,adVarchar,adParamInput,30) %>
<% Set usrPwd=Comm.CreateParameter
(「usrPasswd」,adVarchar,adParamInput,30) %>
<% Set age=Comm.CreateParameter(「age」,adInteger,adParamInput) %>
<% Set PhoneNum=Comm.CreateParameter
(「PhoneNum」,adVarchar,adParamInput, 20) %>
<% Set Address=Comm.CreateParameter(「Address」,adVarchar,adParamInput,50) %>
<% Comm.Parameters.Append usrName %>
<% Comm.Parameters.Append usrPwd %>
<% Comm.Parameters.Append age %>
<% Comm.Parameters.Append PhoneNum %>
<% Comm.Parameters.Append Address %>
<% Comm.Parameters(「usrName」)=request
(「usrName」) %>
<% Comm.Parameters(「usrPasswd」)=request
(「usrPasswd」) %>
<% Comm.Parameters(「age」)=request(「age」) %>
<% Comm.Parameters(「PhoneNum」)=request
(「PhoneNum」) %>
<% Comm.Parameters(「Address」)=request
(「Address」) %>
<% Comm.Execute %>
<% RetValue=Cint(Comm(「RetCode」)) %>
//根據資料庫存儲過程返回代碼判斷注冊是否成功
<% if RetValue< 0 then %>
<% response.Redirect RegisterFail.html %>
<% else %>
<% response.Redirect RegisterOk.html %>
<% end if %>
方法三
利用MTS(Microsoft Transaction Server)組件的事務處理機制實現事務處理時,需要特別注意的是,這種機制下的事務不能跨越多個ASP頁,如果一個事務處理需要來自多個組件的對象,則須將對這些對象的操作組合在一個ASP頁中。
首先需要在頁首添加指令@TRANSACTION,將一個ASP頁面聲明為事務性。@TRANSACTION指令必須在一頁中的第一行,否則將產生錯誤。當頁面中ASP腳本處理結束時,當前事務即告結束。
<%@ TRANSACTION=Required Language=
VB Script %>
//事務執行成功觸發事件
<% Sub OnTransactionCommit() %>
<% response.Redirect RegisterOk.html %>
<% End Sub %>
//事物執行失敗觸發事件
<% Sub OnTransactionAbort() %>
<% response.Redirect RegisterFail.html %>
<% End Sub %>
<% sqlText=「Insert into USER(userName,userPasswd) values(『」 %>
<% sqlText=sqlText & request(「usrName」) & 「』,『」 &request(「usrPasswd」)&「』) 」 %>
<% conn.execute(sqlText) %>
<% if conn.Errors.Count>0 then %>
<% conn.Errors.Clear %>
<% ObjectContext.SetAbort %>
<% end if %>
<% sqlText=「Insert into USERDOC(userName,Age,Sex,PhoneNumber,Address) 」%>
<% sqlText=sqlText & 「values(『」 & request
(「usrName」)& 「』, 」 & request(「Age」) %>
<% sqlText=sqlText & 「,』」 & request
(「PhoneNum」) & 「』,『」 %>
<% sqlText=sqlText & request(「Address」) & 「』) 」 %>
<% conn.execute(sqlText) %>
<% if conn.Errors.Count>0 then %>
<% conn.Errors.Clear %>
<% ObjectContext.SetAbort %>
<% end if %>
<% ObjectContext.SetComplete %>
方案比較
從靈活的角度考慮,選擇採用ASP資料庫組件的方法具有一定的優勢:既可以選用ADO資料庫組件完成事務處理,同時還可以根據實際需要,定製自己的資料庫組件(只要滿足ASP組件編寫規范即可)。如果從資料庫事務處理的可靠性等角度考慮,則採用資料庫內部的事務處理存儲過程更好。這樣可以直接利用資料庫事務機制完成應用程序的邏輯事務處理,安全可靠,並且減少了Web伺服器與資料庫伺服器之間的數據交互。這一點對分布式資料庫系統尤為重要。採用MTS組件的事務處理方法的優勢在於:由MTS伺服器直接控制和管理組件(在MTS中注冊的組件)操作的完成和撤消,具有良好的擴展空間和應用前景,可以充分發揮MTS的技術優勢,增強網路應用的容錯性能,提高IIS Web伺服器的動態性能。
㈨ 怎麼把數據同時插入到資料庫的兩個表中
嚴格意義上講,沒有所謂「同時插入」的手段,只有「要麼都插入(分先後),要麼都不插入」的機制,這個機制就叫做「事務」,是數據顫稿庫服森念務器的執行單位,是原子操作。
由上,將兩個insert命令包裝為一個事務,如下:
declare @OK integer
begin transaction
set @OK = 0
while 1 = 1
begin
insert table1 values( ... )
set @OK = @@error
if @OK <> 0
Break
insert table2 values (... )
set @OK = @@error
Break
end
if @OK = 0
commit transaction
else
rollback transaction
通過觸發器也能實現你的需求,其底層原理依然是事務,觸發器和茄春孝引發它執行的語句被自動地包裝到一個事務中。不過,強烈不建議使用該方法,用此伎倆會導致業務邏輯分散,而人的思維還是需要一定的連貫性,集中在一起顯然有助於表達和理解,當需要改進或者調試錯誤時徒增繁瑣,實在是弊大於利。