1、打開(kāi)PL/SQL Developer,輸入正常的用戶(hù)名密碼后,選擇數(shù)據(jù)庫(kù),然后正常連接。如下圖。
巴林右旗網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),巴林右旗網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為巴林右旗千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站建設(shè)要多少錢(qián),請(qǐng)找那個(gè)售后服務(wù)好的巴林右旗做網(wǎng)站的公司定做!
2、正常登錄后,在PL/SQL Developer中打開(kāi)一個(gè)sql執(zhí)行窗口,操作如下圖1中標(biāo)紅的位置,選擇"SQL Window"。
3、在新出現(xiàn)的空白窗口中輸入正確的sql語(yǔ)句,如下圖。
2、在出現(xiàn)數(shù)據(jù)結(jié)果集后,點(diǎn)擊上圖2中標(biāo)紅的按鈕,出現(xiàn)新的對(duì)話(huà)框。這是要將數(shù)據(jù)結(jié)果集導(dǎo)出成各個(gè)不同的格式。
3、選擇第一個(gè)"CSV file",這樣導(dǎo)出的就是excel格式的數(shù)據(jù)集。
4、打開(kāi)指定的文件夾,就可以看到剛剛導(dǎo)出的文件,雙擊該文件就可以正常打開(kāi),結(jié)果和數(shù)據(jù)庫(kù)中查詢(xún)完出來(lái)的結(jié)果是一致的。
查看及修改oracle編碼格式方法:\x0d\x0a1、查看oracle數(shù)據(jù)庫(kù)字符集:\x0d\x0aselect userenv('language') from dual;\x0d\x0a查詢(xún)結(jié)果:\x0d\x0aSIMPLIFIED CHINESE_CHINA.AL32UTF8\x0d\x0a2、修改oracle數(shù)據(jù)庫(kù)字符集:(在SQL Plus中)\x0d\x0asql conn / as sysdba;\x0d\x0asql shutdown immediate;\x0d\x0adatabase closed.\x0d\x0adatabase dismounted.\x0d\x0aoracle instance shut down.\x0d\x0asql startup mount;\x0d\x0aoracle instance started.\x0d\x0atotal system global area 135337420 bytes\x0d\x0afixed size 452044 bytes\x0d\x0avariable size 109051904 bytes\x0d\x0adatabase buffers 25165824 bytes\x0d\x0aredo buffers 667648 bytes\x0d\x0adatabase mounted.\x0d\x0asql alter system enable restricted session;\x0d\x0asystem altered.\x0d\x0asql alter system set job_queue_processes=0;\x0d\x0asystem altered.\x0d\x0asql alter system set aq_tm_processes=0;\x0d\x0asystem altered.\x0d\x0asql alter database open;\x0d\x0adatabase altered.\x0d\x0asql alter database character set internal_use UTF8\x0d\x0asql shutdown immediate;\x0d\x0asql startup;
在把Oracle查詢(xún)結(jié)果轉(zhuǎn)換為SQL Server的時(shí)候要特別當(dāng)心一些不容易注意到的問(wèn)題。
我們知道,T-SQL是SQL Server的語(yǔ)言引擎,而Oracle的語(yǔ)言引擎卻是PLSQL.這兩種查詢(xún)語(yǔ)言都對(duì)
ANSI SQL-92標(biāo)準(zhǔn)進(jìn)行了擴(kuò)展以提供額外的支持力度。你所創(chuàng)建的應(yīng)用程序幾乎都要用到這些補(bǔ)充特性。本文就對(duì)最常用的、非標(biāo)準(zhǔn)的Oracle擴(kuò)展進(jìn)行了說(shuō)明,同時(shí)還要介紹下如何
對(duì)這些擴(kuò)展進(jìn)行轉(zhuǎn)化以用在SQL Server環(huán)境下。
列的選擇
用PLSQL執(zhí)行數(shù)據(jù)查詢(xún)的時(shí)候,F(xiàn)ROM子句是必須的,這同SQL Server的要求是一樣的。 SELECT語(yǔ)句必須選擇針對(duì)的數(shù)據(jù)表。在Oracle數(shù)據(jù)庫(kù)內(nèi)有一種特殊的表DUAL.DUAL表由
Oracle連同數(shù)據(jù)字典一同創(chuàng)建,所有的用戶(hù)都可以用名稱(chēng)DUAL訪(fǎng)問(wèn)該表。這個(gè)表里只有一列DUMMY,該列定義為VARCHAR2
(1)類(lèi)型,有一行值X.
從DUAL表選擇數(shù)據(jù)常被用來(lái)通過(guò)SELECT語(yǔ)句計(jì)算常數(shù)表達(dá)式,由于DUAL只有一行數(shù)據(jù),所以常數(shù)只返回一次。
Oracle下的DUAL查詢(xún)?nèi)缦滤荆?/p>
SELECT
‘x’ FROM dual
而對(duì)等的SQL Server查詢(xún)則是下面這個(gè)樣子:
SELECT ‘x’
連接
Oracle用|| 符號(hào)作為連接符,而SQL Server的連接符是加號(hào):+ .
Oracle查詢(xún)?nèi)缦滤荆?/p>
Select ‘Name’ || ‘Last Name’
From tableName
對(duì)應(yīng)的SQL Server查詢(xún)?nèi)缦滤荆?/p>
Select ‘Name’ + ‘Last Name’
數(shù)字取舍
Oracle數(shù)據(jù)庫(kù)內(nèi)有一個(gè)TRUNC函數(shù),該函數(shù)返回m位十進(jìn)制數(shù)的n位;如果省略m則n就是0位。m的值可以為負(fù),表示截去小數(shù)點(diǎn)左邊m位數(shù)字。
在SQL Server下可以用Round或者Floor.
以下是Oracle查詢(xún):
SELECT
TRUNC(15.79,1) "Truncate" FROM DUAL;
下面是同類(lèi)查詢(xún)的SQL Server版本:
SELECT ROUND(15.79, 0) rounded ,
ROUND(15.79, 0,1) truncated
SELECT FLOOR(ROUND(15.79, 0)),
FLOOR(ROUND(15.79, 0,1) )
在把Oracle查詢(xún)轉(zhuǎn)換為SQL Server的時(shí)候要特別當(dāng)心一些不容易注意到的問(wèn)題。我們知道,T-SQL是SQL Server的語(yǔ)言引擎,而Oracle的語(yǔ)言引擎卻是PLSQL.這兩種查詢(xún)語(yǔ)言都對(duì)
ANSI SQL-92標(biāo)準(zhǔn)進(jìn)行了擴(kuò)展以提供額外的支持力度。你所創(chuàng)建的應(yīng)用程序幾乎都要用到這些補(bǔ)充特性。本文就對(duì)最常用的、非標(biāo)準(zhǔn)的Oracle擴(kuò)展進(jìn)行了說(shuō)明,同時(shí)還要介紹下如何
對(duì)這些擴(kuò)展進(jìn)行轉(zhuǎn)化以用在SQL Server環(huán)境下。
列的選擇
用PLSQL執(zhí)行數(shù)據(jù)查詢(xún)的時(shí)候,F(xiàn)ROM子句是必須的,這同SQL Server的要求是一樣的。 SELECT語(yǔ)句必須選擇針對(duì)的數(shù)據(jù)表。在Oracle數(shù)據(jù)庫(kù)內(nèi)有一種特殊的表DUAL.DUAL表由
Oracle連同數(shù)據(jù)字典一同創(chuàng)建,所有的用戶(hù)都可以用名稱(chēng)DUAL訪(fǎng)問(wèn)該表。這個(gè)表里只有一列DUMMY,該列定義為VARCHAR2
(1)類(lèi)型,有一行值X.
從DUAL表選擇數(shù)據(jù)常被用來(lái)通過(guò)SELECT語(yǔ)句計(jì)算常數(shù)表達(dá)式,由于DUAL只有一行數(shù)據(jù),所以常數(shù)只返回一次。
Oracle下的DUAL查詢(xún)?nèi)缦滤荆?/p>
SELECT
‘x’ FROM dual
而對(duì)等的SQL Server查詢(xún)則是下面這個(gè)樣子:
SELECT ‘x’
連接
Oracle用|| 符號(hào)作為連接符,而SQL Server的連接符是加號(hào):+ .
Oracle查詢(xún)?nèi)缦滤荆?/p>
Select ‘Name’ || ‘Last Name’
From tableName
對(duì)應(yīng)的SQL Server查詢(xún)?nèi)缦滤荆?/p>
Select ‘Name’ + ‘Last Name’
A、oracle server 端字符集查詢(xún)
select userenv('language') from dual
其中NLS_CHARACTERSET 為server端字符集
NLS_LANGUAGE 為 server端字符顯示形式
B、查詢(xún)oracle client端的字符集
$echo $NLS_LANG
如果發(fā)現(xiàn)你select 出來(lái)的數(shù)據(jù)是亂碼,請(qǐng)把client端的字符集配置成與linux操作系統(tǒng)相同的字符集。如果還是有亂碼,則有可能是數(shù)據(jù)庫(kù)中的數(shù)據(jù)存在問(wèn)題,或者是oracle服務(wù)端的配置存在問(wèn)題。
C、server端字符集修改
將數(shù)據(jù)庫(kù)啟動(dòng)到RESTRICTED模式下做字符集更改:
SQL conn /as sysdba ?Connected.
SQL shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
如果發(fā)現(xiàn)你select 出來(lái)的數(shù)據(jù)是亂碼,請(qǐng)把client端的字符集配置成與linux操作系統(tǒng)相同的字符集。如果還是有亂碼,則有可能是數(shù)據(jù)庫(kù)中的數(shù)據(jù)存在問(wèn)題,或者是oracle服務(wù)端的配置存在問(wèn)題。
.?1.oracle server端字符集查詢(xún)? ? ? ? 復(fù)制代碼代碼如下:? ? select userenv('language') from dual;? ? server字符集修改:? ? 將數(shù)據(jù)庫(kù)啟動(dòng)到RESTRICTED模式下做字符集更改:??
oracle10g服務(wù)器端是安裝在AIX 6.0系統(tǒng)上,客戶(hù)端是安裝在windows server 2008 系統(tǒng)上,客戶(hù)端與服務(wù)器已成功連接,但是數(shù)據(jù)庫(kù)表里的中文字無(wú)法顯示,顯示為“?”,用SQLPLUS查得服務(wù)器端的字符集為AL16uTF16,如何修改該字符集使之支持中文呢?另外oracle10G客戶(hù)端的字符集需不需要設(shè)置,如何查看和設(shè)置呢?