1、對(duì)于提交(最后一次操作commit了)的話可以查詢那個(gè)提交段
創(chuàng)新互聯(lián)擁有十年成都網(wǎng)站建設(shè)工作經(jīng)驗(yàn),為各大企業(yè)提供成都網(wǎng)站建設(shè)、成都做網(wǎng)站服務(wù),對(duì)于網(wǎng)頁(yè)設(shè)計(jì)、PC網(wǎng)站建設(shè)(電腦版網(wǎng)站建設(shè))、重慶APP軟件開(kāi)發(fā)、wap網(wǎng)站建設(shè)(手機(jī)版網(wǎng)站建設(shè))、程序開(kāi)發(fā)、網(wǎng)站優(yōu)化(SEO優(yōu)化)、微網(wǎng)站、域名注冊(cè)等,憑借多年來(lái)在互聯(lián)網(wǎng)的打拼,我們?cè)诨ヂ?lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)積累了很多網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)絡(luò)營(yíng)銷經(jīng)驗(yàn),集策劃、開(kāi)發(fā)、設(shè)計(jì)、營(yíng)銷、管理等網(wǎng)站化運(yùn)作于一體,具備承接各種規(guī)模類型的網(wǎng)站建設(shè)項(xiàng)目的能力。
SELECT 列名1,列名2……
FROM 表名 VERSIONS BETWEEN TIMESTAMP MINVALUE AND MAXVALUE where
VERSIONS_STARTTIME IS NOT null ORDER BY VERSIONS_STARTTIME DESC;
查出來(lái)的第一條就是最后改變的數(shù)據(jù)
2、如果表里面有序列或固定的排序字段可按倒排序后取第一條
where rownum2 order by 排序字段 desc
3、還有另外一種辦法就是利用ORACLE偽列rowid
select * from tbl t1 where t1.rowid=(select max(rowid) from tbl t2)
4、在redo log中找到對(duì)應(yīng)相關(guān)的表的插入語(yǔ)句,但是這樣找到的是sql語(yǔ)句,而不是數(shù)據(jù)。查redo log得使用log miner工具
執(zhí)行下列命令語(yǔ)句
sqlplus / as sysdba EOF
create tablespace test datafile '/data/test01.dbf' size 10240M;
quit;
EOF
通過(guò)ps -ef|grep sqlplus命令得到上面所執(zhí)行的命令的進(jìn)程id為:12345
(1)關(guān)于v$process
執(zhí)行下面的SQL是查不到相關(guān)的信息:
select * from v$process where spid='12345';
因?yàn)檫@個(gè)spid字段對(duì)應(yīng)的并不是我們用ps命令從系統(tǒng)中查詢到的進(jìn)程id,而是這個(gè)進(jìn)程執(zhí)行的當(dāng)前SQL的進(jìn)程id,
也就是上面命令中的“create tablespace test datafile '/data/test01.dbf' size 10240M;”所對(duì)應(yīng)的進(jìn)程id,如果想
通過(guò)用ps命令從系統(tǒng)中查詢到的進(jìn)程id查看對(duì)應(yīng)的信息,那么必須使用下面語(yǔ)句:
select spid,sid,process,sql_address from v$session where process='12345'
上面sql中的process就是通過(guò)ps查看的進(jìn)程id,而spid就是里面的sql語(yǔ)句所對(duì)應(yīng)的進(jìn)程id。
還可以通過(guò)上面的sql_address 查看正在執(zhí)行的SQL語(yǔ)句內(nèi)容:
select sql_text from v$sqlarea s,v$session ses where s.address=ses.sql_address and ses.process='12345';
oracle 在sql中怎么獲取id
1、對(duì)于提交(最后一次操作commit了)的話可以查詢那個(gè)提交段
SELECT 列名1,列名2……
FROM 表名 VERSIONS BETWEEN TIMESTAMP MINVALUE AND MAXVALUE where
VERSIONS_STARTTIME IS NOT null ORDER BY VERSIONS_STARTTIME DESC;
查出來(lái)的第一條就是最后改變的數(shù)據(jù)
2、如果表里面有序列或固定的排序字段可按倒排序后取第一條
where rownum2 order by 排序字段 desc
3、還有另外一種辦法就是利用ORACLE偽列rowid
select * from tbl t1 where t1.rowid=(select max(rowid) from tbl t2)
4、在redo log中找到對(duì)應(yīng)相關(guān)的表的插入語(yǔ)句,但是這樣找到的是sql語(yǔ)句,而不是數(shù)據(jù)。查redo log得使用log miner工具
oracle 中不能設(shè)置自動(dòng)增加,這個(gè)和其他數(shù)據(jù)庫(kù)不一樣,但是有 序列,這個(gè)是Oracle自己特有的東西,
首先創(chuàng)建序列:
create sequence seq;
這就創(chuàng)建好了,然后 seq.nextval 就會(huì)返回一個(gè)值,不會(huì)重復(fù)的值,
insert into tablename values(seq.nextval,'001','javabook');
insert into tablename values(seq.nextval,'001','javabook');
insert into tablename values(seq.nextval,'001','javabook');
這樣前3個(gè)id 分別是 1,2,3
看不了吧。要不要用戶干嘛,就是權(quán)限問(wèn)題。
如果有權(quán)限的話
名稱:select * from user_objects where object_type='PROCEDURE';
存儲(chǔ)過(guò)程代碼:select * from user_source where type='PROCEDURE' and name='....';
用pl/sql或者toad看就比較直接了
select * from dba_users; 查看數(shù)據(jù)庫(kù)里面所有用戶,前提是你是有dba權(quán)限的帳號(hào),如sys,system
select * from all_users;? 查看你能管理的所有用戶!
select * from user_users; 查看當(dāng)前用戶信息 !
擴(kuò)展知識(shí):
Oracle Database,又名Oracle RDBMS,或簡(jiǎn)稱Oracle。是甲骨文公司的一款關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)。它是在數(shù)據(jù)庫(kù)領(lǐng)域一直處于領(lǐng)先地位的產(chǎn)品??梢哉f(shuō)Oracle數(shù)據(jù)庫(kù)系統(tǒng)是目前世界上流行的關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng),系統(tǒng)可移植性好、使用方便、功能強(qiáng),適用于各類大、中、小、微機(jī)環(huán)境。它是一種高效率、可靠性好的 適應(yīng)高吞吐量的數(shù)據(jù)庫(kù)解決方案。
參考資料:百度百科_oracle