Oracle username 集成 AD

  • connect c##acct_admin
    alter session set container=XXX;
    alter user XXX identified globally as 'cn=xx,ou=XXX,ou=ORAC,ou=XXX,ou=XXX Users,dc=XX,dc=XX,dc=cn';

select username, external_name, account_status, lock_date, expiry_date, profile, last_login, password_change_date from dba_users where username='XX';

alter user XXX account unlock;

alter user XXX identified by XXX###;

由AD 登录的用户改为password 登录时需要执行这个,否则password不能正常登录

alter user XXX EXPIRE PASSWORD ROLLOVER PERIOD;

  • The GLOBALLY clause is used when the authentication is done by a external service, like Oracle Internet Directory. (AD)
    GLOBALLY Clause

    The GLOBALLY clause lets you create a global user. Such a user must be authorized by the enterprise directory service (Oracle Internet Directory).

    The <span class="codeinlineitalic">directory_DN</span> string can take one of two forms:

    • The X.509 name at the enterprise directory service that identifies this user. It should be of the form CN=``<span class="codeinlineitalic">username,other_attributes</span>, where <span class="codeinlineitalic">other_attributes</span> is the rest of the user's distinguished name (DN) in the directory. This form creates a private global schema.

    • A null string (' ') indicating that the enterprise directory service will map authenticated global users to this database schema with the appropriate roles. This form is the same as specifying the GLOBALLY keyword alone and creates a shared global schema.

    The maximum length of <span class="codeinlineitalic">directory_DN</span> is 1024 characters.

    You can control the ability of an application server to connect as the specified user and to activate that user's roles using the ALTER USER statement.

Creating a Global User Example:

Creating a Global Database User: Example The following example creates a global user. When you create a global user, you can specify the X.509 name that identifies this user at the enterprise directory server:

复制代码
CREATE USER global_user
   IDENTIFIED GLOBALLY AS 'CN=analyst, OU=division1, O=oracle, C=US'
   DEFAULT TABLESPACE example
   QUOTA 5M ON example;

· Scott is authenticated by SSL and authorized by the enterprise directory service.

·The AS clause provides a string identifier (distinguished name -- DN) to the enterprise directory.

· Disadvantage: Scott must have a user account created in every database to be accessed as well as in the directory service.

Summary

Create user from dynamic SQL EXECUTE IMMEDIATE CREATE USER IDENTIFIED GLOBALLY failing:

Trying to execute a simple "create user ... IDENTIFIED GLOBALLY as '' from dynamic SQL.

declare

cn VARCHAR2(1000):='CN=user1,OU=Laptop Users,OU=Active Accounts,DC=int,DC=us,DC=oracle,DC=com';

begin

execute immediate 'create user USER1 IDENTIFIED GLOBALLY as '||CHR(34)||cn||CHR(34)||' ;';

end;

declare

*

ERROR at line 1:

ORA-00972: identifier is too long

ORA-06512: at line 4

or

*

11.2.0.4 DB Error:

ERROR at line 1:

ORA-00911: invalid character

ORA-06512: at line 4

or

12.1.0.2 DB Error:

ERROR at line 1:

ORA-00922: missing or invalid option

ORA-06512: at line 4

Solution

Do not use ';' in the sql statement executed thru execute immediate command.

declare

cn VARCHAR2(1000):='CN=user1,OU=Laptop Users,OU=Active Accounts,DC=int,DC=us,DC=oracle,DC=com';

begin

execute immediate 'create user USER1 IDENTIFIED GLOBALLY as '||CHR(34)||cn||CHR(34);

end;

相关推荐
herinspace3 分钟前
管家婆实用帖-如何使用ping命令检测网络环境
网络·数据库·人工智能·学习·excel·语音识别
星空椰3 分钟前
Windows 安装 PostgreSQL 数据库
数据库·postgresql
Elastic 中国社区官方博客11 分钟前
用于 IntelliJ IDEA 的新 ES|QL 插件
java·大数据·数据库·ide·elasticsearch·搜索引擎·intellij-idea
疯狂成瘾者13 分钟前
LangChain Middleware 技术解析:从“插槽机制”到 Agent 运行时控制
数据库·python·langchain
七夜zippoe17 分钟前
OpenClaw 飞书深度集成:多维表格
数据库·算法·飞书·集成·openclaw
A-刘晨阳23 分钟前
当数据学会“秒回“:工业4.0时代的实时计算革命
开发语言·数据库·perl
2201_7568473336 分钟前
如何设置备库只接日志不应用_暂停MRP且维持网络传输的方法
jvm·数据库·python
dualven_in_csdn42 分钟前
EMQX 开启 **MySQL + password_based** 认证
android·数据库·mysql
Jul1en_1 小时前
【Redis】单线程模型
数据库·redis·缓存
Arva .1 小时前
Spring 事务传播机制 速记
java·数据库·spring