SQLSERVER與ACCESS、EXCEL的數(shù)據(jù)轉(zhuǎn)換

字號:

熟悉SQL SERVER 2000的數(shù)據(jù)庫管理員都知道,其DTS可以進行數(shù)據(jù)的導(dǎo)入導(dǎo)出,其實,我們也可以使用Transact-SQL語句進行導(dǎo)入導(dǎo)出操作。在Transact-SQL語句中,我們主要使用OpenDataSource函數(shù)、OPENROWSET 函數(shù),關(guān)于函數(shù)的詳細(xì)說明,請參考SQL聯(lián)機幫助。利用下述方法,可以十分容易地實現(xiàn)SQL SERVER、ACCESS、EXCEL數(shù)據(jù)轉(zhuǎn)換,詳細(xì)說明如下:
    一、SQL SERVER 和ACCESS的數(shù)據(jù)導(dǎo)入導(dǎo)出
    常規(guī)的數(shù)據(jù)導(dǎo)入導(dǎo)出:
    使用DTS向?qū)нw移你的Access數(shù)據(jù)到SQL Server,你可以使用這些步驟:
    1.在SQL SERVER企業(yè)管理器中的Tools(工具)菜單上,選擇Data Transformation
    2.Services(數(shù)據(jù)轉(zhuǎn)換服務(wù)),然后選擇 czdImport Data(導(dǎo)入數(shù)據(jù))。
    3.在Choose a Data Source(選擇數(shù)據(jù)源)對話框中選擇Microsoft Access as the Source,然后鍵入你的.mdb數(shù)據(jù)庫(.mdb文件擴展名)的文件名或通過瀏覽尋找該文件。
    4.在Choose a Destination(選擇目標(biāo))對話框中,選擇Microsoft OLE DB Prov ider for SQL Server,選擇數(shù)據(jù)庫服務(wù)器,然后單擊必要的驗證方式。
    5.在Specify Table Copy(指定表格復(fù)制)或Query(查詢)對話框中,單擊Copy tables(復(fù)制表格)。
    6在Select Source Tables(選擇源表格)對話框中,單擊Select All(全部選定)。下一步,完成。
    Transact-SQL語句進行導(dǎo)入導(dǎo)出:
    1. 在SQL SERVER里查詢access數(shù)據(jù):
    -- ======================================================
    SELECT *
    FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
    'Data Source="c:\DB.mdb";User ID=Admin;Password=')...表名
    -------------------------------------------------------------------------------------------------
       2. 將access導(dǎo)入SQL server
    -- ======================================================
    在SQL SERVER 里運行:
    SELECT *
    INTO newtable
    FROM OPENDATASOURCE ('Microsoft.Jet.OLEDB.4.0',
     'Data Source="c:\DB.mdb";User ID=Admin;Password=' )...表名
    -------------------------------------------------------------------------------------------------
       3. 將SQL SERVER表里的數(shù)據(jù)插入到Access表中
    -- ======================================================
    在SQL SERVER 里運行:
    insert into OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',
        'Data Source=" c:\DB.mdb";User ID=Admin;Password=')...表名
    (列名1,列名2)
    select 列名1,列名2 from sql表
    實例:
    insert into OPENROWSET('Microsoft.Jet.OLEDB.4.0',
    'C:\db.mdb';'admin';'', Test)
    select id,name from Test
    INSERT INTO OPENROWSET('Microsoft.Jet.OLEDB.4.0', 'c:\trade.mdb'; 'admin'; '', 表名)
    SELECT *
    FROM sqltablename
    -------------------------------------------------------------------------------------------------