欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ORACLE查看當(dāng)前賬號(hào)的相關(guān)信息

 更新時(shí)間:2021年06月16日 15:23:03   作者:瀟湘隱者  
ORACLE 12C 后新增了一個(gè)功能,它會(huì)記錄用戶的最后一次登錄時(shí)間:SPARE6字段記錄用戶的最后一次登錄時(shí)間,本文給大家ORACLE如何查看當(dāng)前賬號(hào)的相關(guān)信息,感興趣的朋友一起看看吧

關(guān)于Oracle數(shù)據(jù)庫(kù)的賬號(hào),我們?cè)诰S護(hù)數(shù)據(jù)庫(kù)的時(shí)候,偶爾可能需要獲取一些特殊信息。例如,賬號(hào)的創(chuàng)建時(shí)間、賬號(hào)的狀態(tài)、賬號(hào)的鎖定時(shí)間.....。正常情況下,我們可以通過(guò)DBA_USERS獲取大部分相關(guān)信息。但是有一些特殊信息,還必須通過(guò)不常用底層基表sys.user$來(lái)獲取。

SQL> DESC DBA_USERS;
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 USERNAME                                  NOT NULL VARCHAR2(30)
 USER_ID                                   NOT NULL NUMBER
 PASSWORD                                           VARCHAR2(30)
 ACCOUNT_STATUS                            NOT NULL VARCHAR2(32)
 LOCK_DATE                                          DATE
 EXPIRY_DATE                                        DATE
 DEFAULT_TABLESPACE                        NOT NULL VARCHAR2(30)
 TEMPORARY_TABLESPACE                      NOT NULL VARCHAR2(30)
 CREATED                                   NOT NULL DATE
 PROFILE                                   NOT NULL VARCHAR2(30)
 INITIAL_RSRC_CONSUMER_GROUP                        VARCHAR2(30)
 EXTERNAL_NAME                                      VARCHAR2(4000)

其實(shí)我們經(jīng)常使用的DBA_USERS是同義詞,對(duì)應(yīng)SYS.DBA_USERS這個(gè)視圖。如果你想查看SYS.DBA_USERS的定義,可以通過(guò)下面方式:

--ORACLE 10g
 
SQL>SELECT DBMS_METADATA.GET_DDL('VIEW', 'DBA_USERS', 'SYS') FROM DUAL;
 
 
 CREATE OR REPLACE FORCE VIEW "SYS"."DBA_USERS" (
  "USERNAME"
, "USER_ID"
, "PASSWORD"
, "ACCOUNT_STATUS"
, "LOCK_DATE"
, "EXPIRY_DATE"
, "DEFAULT_TABLESPACE"
, "TEMPORARY_TABLESPACE"
, "CREATED"
, "PROFILE"
, "INITIAL_RSRC_CONSUMER_GROUP"
, "EXTERNAL_NAME") AS 
  select u.name, u.user#, u.password,
       m.status,
       decode(u.astatus, 4, u.ltime,
                         5, u.ltime,
                         6, u.ltime,
                         8, u.ltime,
                         9, u.ltime,
                         10, u.ltime, to_date(NULL)),
       decode(u.astatus,
              1, u.exptime,
              2, u.exptime,
              5, u.exptime,
              6, u.exptime,
              9, u.exptime,
              10, u.exptime,
              decode(u.ptime, '', to_date(NULL),
                decode(pr.limit#, 2147483647, to_date(NULL),
                 decode(pr.limit#, 0,
                   decode(dp.limit#, 2147483647, to_date(NULL), u.ptime +
                     dp.limit#/86400),
                   u.ptime + pr.limit#/86400)))),
       dts.name, tts.name, u.ctime, p.name,
       nvl(cgm.consumer_group, 'DEFAULT_CONSUMER_GROUP'),
       u.ext_username
       from sys.user$ u left outer join sys.resource_group_mapping$ cgm
            on (cgm.attribute = 'ORACLE_USER' and cgm.status = 'ACTIVE' and
                cgm.value = u.name),
            sys.ts$ dts, sys.ts$ tts, sys.profname$ p,
            sys.user_astatus_map m, sys.profile$ pr, sys.profile$ dp
       where u.datats# = dts.ts#
       and u.resource$ = p.profile#
       and u.tempts# = tts.ts#
       and u.astatus = m.status#
       and u.type# = 1
       and u.resource$ = pr.profile#
       and dp.profile# = 0
       and dp.type#=1
       and dp.resource#=1
       and pr.type# = 1
       and pr.resource# = 1

通過(guò)上面的視圖定義,我們可以知道,大部分?jǐn)?shù)據(jù)來(lái)自于底層基表sys.user$。關(guān)于表sys.user$的結(jié)構(gòu)如下,我們可以從sql.bsq中可以看到sys.user$的定義。

SQL> DESC sys.user$
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 USER#                                     NOT NULL NUMBER
 NAME                                      NOT NULL VARCHAR2(30)    
 TYPE#                                     NOT NULL NUMBER
 PASSWORD                                           VARCHAR2(30)
 DATATS#                                   NOT NULL NUMBER
 TEMPTS#                                   NOT NULL NUMBER
 CTIME                                     NOT NULL DATE
 PTIME                                              DATE
 EXPTIME                                            DATE
 LTIME                                              DATE
 RESOURCE$                                 NOT NULL NUMBER
 AUDIT$                                             VARCHAR2(38)
 DEFROLE                                   NOT NULL NUMBER
 DEFGRP#                                            NUMBER
 DEFGRP_SEQ#                                        NUMBER
 ASTATUS                                   NOT NULL NUMBER
 LCOUNT                                    NOT NULL NUMBER
 DEFSCHCLASS                                        VARCHAR2(30)
 EXT_USERNAME                                       VARCHAR2(4000)
 SPARE1                                             NUMBER
 SPARE2                                             NUMBER
 SPARE3                                             NUMBER
 SPARE4                                             VARCHAR2(1000)
 SPARE5                                             VARCHAR2(1000)
 SPARE6                                             DATE

其中,我們可以獲取一下關(guān)鍵字段信息,具體如下

NAME         用戶(User)或角色(Role)的名字 
TYPE#        0表示Role,1表示User
CTIME        用戶的創(chuàng)建時(shí)間
PTIME        密碼最后一次修改時(shí)間
EXPTIME      密碼過(guò)期的時(shí)間
LTIME        賬號(hào)最后一次鎖定的時(shí)間
LCOUNT       用戶登錄失敗次數(shù)。

下面我們簡(jiǎn)單測(cè)試驗(yàn)證一下,

SQL> CREATE USER TEST IDENTIFIED BY "Test#1232134$#3" DEFAULT TABLESPACE TBS_TEST_DATA TEMPORARY TABLESPACE  TEMP;
 
User created.
SQL> GRANT CONNECT TO TEST;
SQL> @get_user_info.sql
 
Session altered.
 
Enter value for user_name: TEST
old   9: WHERE NAME=('&USER_NAME')
new   9: WHERE NAME=('TEST')
 
NAME                                TYPE# CTIME               PTIME               EXPTIME             LTIME                   LCOUNT
------------------------------ ---------- ------------------- ------------------- ------------------- ------------------- ----------
TEST                                    1 2021-06-10 14:10:01 2021-06-10 14:10:01                                                  0
 
SQL> ALTER USER TEST IDENTIFIED BY "kER124";
 
User altered.
 
SQL> @get_user_info.sql
 
Session altered.
 
Enter value for user_name: TEST
old   9: WHERE NAME=('&USER_NAME')
new   9: WHERE NAME=('TEST')
 
NAME                                TYPE# CTIME               PTIME               EXPTIME             LTIME                   LCOUNT
------------------------------ ---------- ------------------- ------------------- ------------------- ------------------- ----------
TEST                                    1 2021-06-10 14:10:01 2021-06-10 14:10:50                                                  0
 
SQL> ALTER USER TEST ACCOUNT LOCK;
 
User altered.
 
SQL> @get_user_info.sql
 
Session altered.
 
Enter value for user_name: TEST
old   9: WHERE NAME=('&USER_NAME')
new   9: WHERE NAME=('TEST')
 
NAME                                TYPE# CTIME               PTIME               EXPTIME             LTIME                   LCOUNT
------------------------------ ---------- ------------------- ------------------- ------------------- ------------------- ----------
TEST                                    1 2021-06-10 14:10:01 2021-06-10 14:10:50                     2021-06-10 14:11:27          0
 
SQL> 

其中g(shù)et_user_info.sql的腳本如下

$ more get_user_info.sql 
ALTER SESSION SET NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS';
SELECT  NAME
      , TYPE#
      , CTIME
      , PTIME
      , EXPTIME
      , LTIME
      , LCOUNT
FROM user$
WHERE NAME=('&USER_NAME');

另外,我們來(lái)測(cè)試一下賬號(hào)登錄失敗次數(shù),在實(shí)驗(yàn)前先解鎖賬號(hào),用錯(cuò)誤的賬號(hào)密碼嘗試登錄數(shù)據(jù)庫(kù),你會(huì)發(fā)現(xiàn)LCOUNT就變成1了。

SQL> @get_user_info.sql
 
Session altered.
 
Enter value for user_name: TEST
old   9: WHERE NAME=('&USER_NAME')
new   9: WHERE NAME=('TEST')
 
NAME                                TYPE# CTIME               PTIME               EXPTIME             LTIME                   LCOUNT
------------------------------ ---------- ------------------- ------------------- ------------------- ------------------- ----------
TEST                                    1 2021-06-10 14:10:01 2021-06-10 14:10:50                     2021-06-10 14:11:27          1
 
SQL> 

那么這個(gè)LCOUNT字段的值是一直累加到超過(guò)閾值鎖定呢?還是中間會(huì)清零呢?什么情況下會(huì)清零呢? 如果你使用正確的密碼成功登錄數(shù)據(jù)庫(kù)后,你會(huì)發(fā)現(xiàn)LCOUNT的值就清零了。如下截圖所示:

$ sqlplus /nolog
 
SQL*Plus: Release 10.2.0.4.0 - Production on Thu Jun 10 14:30:41 2021
 
Copyright (c) 1982, 2007, Oracle.  All Rights Reserved.
 
SQL> connect TEST
Enter password: 
Connected.

也就是說(shuō),只要你在鎖定之前,一旦成功登錄之后,該計(jì)數(shù)會(huì)被清零。在有些版本中,由于Bug,也會(huì)出現(xiàn)LCOUNT沒(méi)有正確反映登錄失敗次數(shù)的情況,例如Lcount neither reset on correct login nor incremented after incorrect login thru JDBC (Doc ID 2675398.1)中記錄了這樣的Bug。另外,ORACLE 12C 后新增了一個(gè)功能,它會(huì)記錄用戶的最后一次登錄時(shí)間:SPARE6字段記錄用戶的最后一次登錄時(shí)間

參考資料:

https://www.eygle.com/archives/2009/07/profile_failed_login_attempts.html

https://dbaora.com/sys-user-table-in-oracle-last-password-change-time-last-locked-last-expired-creation-time-failed-logon/

Lcount neither reset on correct login nor incremented after incorrect login thru JDBC (Doc ID 2675398.1)

https://bijoos.com/oraclenotes/2013/153/

以上就是ORACLE如何查看當(dāng)前賬號(hào)的相關(guān)信息總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于oracle查看當(dāng)前賬號(hào)信息的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 使用IDEA對(duì)Oracle數(shù)據(jù)庫(kù)進(jìn)行簡(jiǎn)單增刪改查操作

    使用IDEA對(duì)Oracle數(shù)據(jù)庫(kù)進(jìn)行簡(jiǎn)單增刪改查操作

    這篇文章主要介紹了使用IDEA對(duì)Oracle數(shù)據(jù)庫(kù)進(jìn)行簡(jiǎn)單增刪改查操作,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • Oracle?ORA-00904:標(biāo)識(shí)符無(wú)效解決方法(太坑了!!)

    Oracle?ORA-00904:標(biāo)識(shí)符無(wú)效解決方法(太坑了!!)

    最近執(zhí)行sql時(shí)oracle報(bào)錯(cuò)ORA-00904:標(biāo)識(shí)符無(wú)效,所以這篇文章主要給大家介紹了關(guān)于Oracle?ORA-00904:標(biāo)識(shí)符無(wú)效解決方法的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Oracle中pivot函數(shù)圖文實(shí)例詳解

    Oracle中pivot函數(shù)圖文實(shí)例詳解

    pivot操作是一種數(shù)據(jù)處理方法,可以將一個(gè)表中的行數(shù)據(jù)轉(zhuǎn)換為列數(shù)據(jù),這種轉(zhuǎn)換對(duì)于表格數(shù)據(jù)的分析和展示非常有用,下面這篇文章主要給大家介紹了關(guān)于Oracle中pivot函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • 詳解Oracle的sqlldr理論

    詳解Oracle的sqlldr理論

    這篇文章主要介紹了詳解Oracle的sqlldr理論,SQL*LOADER是ORACLE的數(shù)據(jù)加載工具,通常用來(lái)將操作系統(tǒng)文件(數(shù)據(jù))遷移到ORACLE數(shù)據(jù)庫(kù)中,SQL*LOADER是大型數(shù)據(jù)倉(cāng)庫(kù)選擇使用的加載方法,因?yàn)樗峁┝俗羁焖俚耐緩?DIRECT,PARALLEL),需要的朋友可以參考下
    2023-07-07
  • Oracle 系統(tǒng)變量函數(shù)用法指南

    Oracle 系統(tǒng)變量函數(shù)用法指南

    在Oracle數(shù)據(jù)庫(kù)中,Oracle系統(tǒng)變量函數(shù)是經(jīng)常會(huì)使用到的函數(shù),分享下Oracle系統(tǒng)變量函數(shù)的用法。希望對(duì)大家有所幫助
    2014-08-08
  • 解讀Oracle中代替like進(jìn)行模糊查詢的方法instr(更高效)

    解讀Oracle中代替like進(jìn)行模糊查詢的方法instr(更高效)

    這篇文章主要介紹了解讀Oracle中代替like進(jìn)行模糊查詢的方法instr(更高效),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • oracle數(shù)據(jù)庫(kù)密碼到期怎么解決

    oracle數(shù)據(jù)庫(kù)密碼到期怎么解決

    這篇文章主要介紹了oracle數(shù)據(jù)庫(kù)密碼到期的解決方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下
    2017-02-02
  • 淺析Oracle和Mysql分頁(yè)的區(qū)別

    淺析Oracle和Mysql分頁(yè)的區(qū)別

    Mysql使用limit分頁(yè)而Oracle使用rownum分頁(yè),下面通過(guò)本文給大家介紹Oracle和Mysql分頁(yè)的區(qū)別,需要的的朋友參考下吧
    2017-09-09
  • oracle中l(wèi)eft join和right join的區(qū)別淺談

    oracle中l(wèi)eft join和right join的區(qū)別淺談

    oracle中l(wèi)eft join和right join的區(qū)別淺談,需要的朋友可以參考一下
    2013-02-02
  • Oracle 12CR2查詢轉(zhuǎn)換教程之表擴(kuò)展詳解

    Oracle 12CR2查詢轉(zhuǎn)換教程之表擴(kuò)展詳解

    Oracle 12cR2版本已經(jīng)發(fā)布有一段時(shí)間,下面這篇文章主要給大家介紹了關(guān)于Oracle 12CR2查詢轉(zhuǎn)換教程之表擴(kuò)展的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-11-11

最新評(píng)論