1/s/1gfa3e63;這里是我在Oracle官網下載好了Windows系統(tǒng)64位的安裝包,有2個zip文件。不想去官網找下載地址的童鞋可以直接用這個百度云盤的下載鏈接。1.去下載最新的oracle11g安裝包的壓縮文件,有2個壓縮文件,都需要下載,下載完成以后需要解壓縮在同一個目錄下。在開始oracle數據安裝之前建議:1.關閉本機的病毒防火墻。2.斷開互聯(lián)網。這樣可以避免解壓縮丟失文件和安裝失敗。2.我在下載好2個zip文件后,都解壓在了database目錄中。如下圖:3.進入database雙擊 setup.exe 開始安裝,在如下圖:4.出現(xiàn)如下選項,選擇是,繼續(xù)安裝。當然這是我機器出現(xiàn)了這個情況,可能你的滿足要求了。。。5.取消勾,點擊下一步:6.Oracle在進行安裝的時候都會詢問是否同時創(chuàng)建一個數據庫出來,此處選擇“創(chuàng)建和配置數據庫”。7.每一個數據庫可以想象為一個實例,所以此處表示只存在一個數據庫的含義8.此處選擇“高級安裝”。9.語言現(xiàn)在選擇支持“簡體中文”和“英文”。10.選擇“企業(yè)版”。11.此處設置Oracle的安裝目錄,將其安裝到app目錄下。12.選擇一般事物 13.此處輸入數據庫的名稱,同時SID與數據庫的名稱相同。14.使用默認配置,如下圖:15.Oracle本身提供了多個操作用戶,為了簡單管理,所有的密碼都統(tǒng)一設置為“oracleadmin”。隨后將進行安裝環(huán)境的檢驗,如果檢驗之中出現(xiàn)了錯誤,則會提示用戶,或者由用戶選擇“忽略”。16.選擇完成開始安裝17.而后進入到了oracle的安裝界面。此界面會運行一段時間,在此界面完成之后出現(xiàn)的任何界面都不要點任何的確定按鈕,因為還需要進行后續(xù)的配置。18.安裝完成之后會進入到配置用戶口令界面,點擊 用戶口令 設置密碼。此界面之中需要進行用戶名及密碼的配置,在使用Oracle數據庫過程之中,主要使用三個用戶(有三個用戶的密碼是public password,在實際中不可以使用):超級管理員:sys / change_on_install;普通管理員:system / manager;普通用戶:scott / tiger,此用戶需要配置解鎖;19.完成之后選擇“確定”那么再之后就可以進入到安裝完成的界面,選擇“關閉”即可。20.在Oracle安裝完成之后,可以通過windows的服務找到所有與Oracle有關的服務選項。21.所有的服務建議將其全部修改為手工啟動,這樣電腦的啟動速度可以快一些。但是有兩個服務是必須啟動的:OracleOraDb11g_home1TNSListener:數據庫的監(jiān)聽服務,當使用任何的編程語言或者是前臺工具連接數據庫的時候,此服務必須啟動,否則無法連接;OracleServiceSYNC:指的是數據庫的實例服務,實例服務的命名規(guī)范“OracleServiceSID”,一般SID的名稱都和數據庫的名稱保持一致,每一個數據庫的服務都會創(chuàng)建一個sid。這里我的數據庫的SID是sync。2. 使用sqlplus命令設置數據庫1.當oracle安裝完成之后,下面就需要對其進行使用,Oracle本身提供了一個“sqlplus.exe”的操作命令,直接運行此命令即可。2.此處輸入用戶名為scott,密碼為tiger。 3.在數據庫之中會存在多張數據表,那么下面發(fā)出一個查詢emp表的操作命令,輸入命令如下,默認的顯示方式并不是特別的好,此處可以使用以下的命令更改顯示方式 4.在Oracle之中會存在多種用戶,如果要想切換不同的用戶,可以使用如下的命令完成,如果現(xiàn)在使用的是sys用戶登錄,那么就必須加上“AS SYSDBA”表示由管理員登錄,其他用戶不需要。CONN 用戶名/密碼 [AS SYSDBA] ;范例:使用sys登錄conn sys/change_on_install AS sysdba 如果要想查看當前用戶輸入“show user”命令即可查看。show user 5.如果說現(xiàn)在使用sys用戶登錄,并且發(fā)出同樣的查詢命令,會發(fā)現(xiàn)找不到emp表的錯誤提示:6.因為這張表屬于scott用戶,所以當使用scott用戶登錄的時候可以直接使用此表,但是如果換了一個用戶,那么就必須使用這個表的完整名稱“用戶名.表名稱”,emp屬于scott的,所以全名是“scott.emp”。以上所述是小編給大家?guī)淼腛racle11g數據庫win8.1系統(tǒng)安裝配置圖文教程,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
創(chuàng)新互聯(lián)建站是一家成都網站制作、做網站,提供網頁設計,網站設計,網站制作,建網站,按需規(guī)劃網站,網站開發(fā)公司,自2013年起是互聯(lián)行業(yè)建設者,服務者。以提升客戶品牌價值為核心業(yè)務,全程參與項目的網站策劃設計制作,前端開發(fā),后臺程序制作以及后期項目運營并提出專業(yè)建議和思路。
批量插入數據腳本
1、第一種批量插入數據腳本,可以基本滿足要求。理解上較為簡單,所以這個最常用。
NEXTVAL和CURRVAL的區(qū)別:
1、如果 sequence.CURRVAL 和 sequence.NEXTVAL 都出現(xiàn)在一個 SQL 語句中,則序列只增加一次。在這種情況下,每個 sequence.CURRVAL 和 sequence.NEXTVAL 表達式都返回相同的值,不管在語句中sequence.CURRVAL 和 sequence.NEXTVAL 的順序。
執(zhí)行腳本結果如下:
3、兩個表,同時批量插入數據的腳本
3、
4、 涉及子表時,批量插入數據腳本,
5、 批量修改數據 :
時間取數方式:
一、SYSTIMESTAMP(取當前系統(tǒng)值)
二、SYSDATE(取當前系統(tǒng)值,但只精確到時,分和秒都為0)
三、固定值為:TO_TIMESTAMP ('2019-2-12 15:24:45.703000', 'yyyy-mm-dd hh24:mi:ss.ff6')
把固定的字段改為變量:
方式一:’||i||’ 例:’{“no”:“111’||i||’”}’(此方式)
方式二:concat 例:concat(concat(’{“blNo”:111"’,i),’"}’)
#!/bin/bash
#centos oracle g 前期安裝環(huán)境檢查腳本
#將所需要安裝的包(rpm格式)與腳本放在一個目錄下
ss=$PWD
cd $ss
rpm ivh * rpm
#ORACLE_BASE=/opt/oracle
echo n 輸入ORACLE_BASE(默認/opt/oracle):
read ORACLE_BASE
if [ z $ORACLE_BASE ]
then
ORACLE_BASE=/opt/oracle
fi
#ORACLE_HOME=$ORACLE_BASE/product/ /db_
echo n 輸入 HOME (默認 product/ /db_ ):
read HOME
if [ z $HOME ]
then
HOME=product/ /db_
fi
ORACLE_HOME=$ORACLE_BASE/$HOME
#ORACLE_SID=oral
echo n 輸入 ORACLE_SID (默認 orcl):
read ORACLE_SID
if [ z $ORACLE_SID ]
then
ORACLE_SID=orcl
fi
USER=oracle
SYSCTL=/etc/nf
LIMITS=/etc/security/nf
PAM=/etc/pam d/login
PROFILE=/etc/profile
BASH_PROFILE=/home/oracle/ bash_profile
#IPADDR=`ifconfig eth |grep inet addr |cut d : f | cut d f `
#HOSTS=/etc/hosts
#NEORK=/etc/sysconfig/neork
#hostname
#grep v HOSTNAME $NEORK $NEORK
#echo HOSTNAME=$HOSTNAME $NEORK
#echo $IPADDR $HOSTNAME $HOSTS
#加入用戶
useradd g oinstall G dba? $USER
groupadd oinstall
groupadd dba
mkdir p $ORACLE_BASE
chown R $USER:oinstall $ORACLE_BASE
#內核設置
cat $SYSCTL EOF
kernel msgmni=
kernel shmmni=
kernel sem=
fs file max=
net ipv ip_local_port_range=
net ipv tcp_sack=
net ipv tcp_timestamps=
net ipv tcp_max_syn_backlog=
net ipv tcp_keepalive_time=
re rmem_default=
re rmem_max=
re wmem_default=
re wmem_max=
EOF
#限制設置
cat $LIMITS EOF
oracle????????????? soft??? nproc??
oracle????????????? hard??? nproc??
oracle????????????? soft??? nofile?
oracle????????????? hard??? nofile?
EOF
#安全設置
cat $PAM EOF
session??? required???? /lib/security/pam_limits so
session??? required???? pam_limits so
EOF
#全局環(huán)境變量設置
cat $PROFILE EOF
if [ \$USER = oracle ]; then
if [ \$SHELL = /bin/ksh ]; then
ulimit p
ulimit n
else
ulimit u n
fi
fi
EOF
#oracle環(huán)境變量設置
cat $BASH_PROFILE EOF
export LC_CTYPE=en_US UTF
export ORACLE_SID=orcl
export ORACLE_BASE=/opt/oracle
export ORACLE_HOME=/opt/oracle/product/ /db_
export TNS_ADMIN=$ORACLE_HOME/neork/admin
export ORA_DB=$ORACLE_HOME/dbs
export ORACLE_BDUMP=$ORACLE_BASE/shtkt/bdump
export ORACLE_TERM=xterm
export NLS_LANG=AMERICAN_AMERICA ZHS GBK
export ORA_NLS =$ORACLE_HOME/omon/nls/admin/data
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib:/usr/local/lib
export LIBPATH=$ORACLE_HOME/lib:$ORACLE_HOME/ctx/lib
export CLASSPATH=$ORACLE_HOME/JRE/lib:$ORACLE_HOME/JRE/lib/rt jar:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib
PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin
export PATH
umask
EOF
source /home/oracle/ bash_profile
sleep
export DISPLAY=:
xhost +
export LC_ALL=en_US
lishixinzhi/Article/program/Oracle/201311/18577
沒必要用root權限執(zhí)行,oracle用戶同樣可以執(zhí)行crontab計劃任務
1、su - oracle
crontab -e
0 4 * * 0 /home/oracle/exp.sh 21 /home/oracle/script_exp.log;
0~59 表示分
0~23 表示小時
1~31 表示日
1~12 表示月份
0~6 表示星期(其中0表示星期日)
2、cat /home/oracle/exp.sh
. ~/.bash_profile
bakdir=/opt/dbbak
logdir=/home/oracle/dbbak
rq=$(date +%Y%m%d)
exp system/***** owner=jysh file=${bakdir}/jysh_${rq}.dmp log=${logdir}/jysh_${rq}.log;
find ${bakdir} -type f -mtime +30 -exec rm -rf {} \;
用job,具體用法:
declare
n_job binary_integer;
begin
dbms_job.submit(n_job, '你要執(zhí)行的東西', sysdate, TRUNC(LAST_DAY(SYSDATE))+4+2/24);
end;
-- 每月4號執(zhí)行
dbms_job.submit(n_job_01,'你調的東西',sysdate,'TRUNC(LAST_DAY(SYSDATE))+4+2/24');
-- 每分鐘執(zhí)行一次
dbms_job.submit(n_job_01,'你調的東西',sysdate,'TRUNC(sysdate,’mi’) + 1 / (24*60)');
-- 凌晨兩點執(zhí)行
dbms_job.submit(n_job_01,'你調的東西',sysdate,'TRUNC(sysdate) + 1 + 2/24');
-- 每周一凌晨2點執(zhí)行 周一是每周的第二天next_day(sysdate,2)同理周二是第三天,next_day(sysdate,3)
dbms_job.submit(n_job_01,'你調的東西',sysdate,'TRUNC(next_day(sysdate,2))+2/24');
-- 每月1日凌晨兩點執(zhí)行
dbms_job.submit(n_job_01,'你調的東西',sysdate,'TRUNC(LAST_DAY(SYSDATE))+1+2/24');
-- 每季第一天凌晨兩點執(zhí)行
dbms_job.submit(n_job_01,'你調的東西',sysdate,'TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 2/24');
-- 每年7月1日和1月1日凌晨2點
dbms_job.submit(n_job_01,'你調的東西',sysdate,'ADD_MONTHS(trunc(sysdate,'yyyy'),6)+2/24');
-- 每年1月1日凌晨2點執(zhí)行
dbms_job.submit(n_job_01,'你調的東西',sysdate, 'Add_months(trunc(sysdate,'yyyy'), 12) +2/24');