LightDB 23.1相容Oracle新特性支援

哎呀我的天吶發表於2023-02-17

22.3中LightDB相容Oracle語法做了增強
新特性相容如下:

  • grant connect/resource語句
  • drop user test cascade;

grant connect/resource語句

如下語句在LightDB中可以執行成功
切換到Oracle模式的資料庫test中執行,執行下面語句確認

show lightdb_dblevel_syntax_compatible_type;
Oracle

返回Oracle說明資料庫庫Oracle模式

lightdb@test=# CREATE USER TEST IDENTIFIED BY test DEFAULT TABLESPACE test TEMPORARY TABLESPACE test; CREATE ROLElightdb@test=# GRANT CONNECT TO TEST;GRANT ROLElightdb@test=# GRANT RESOURCE TO TEST;GRANT ROLElightdb@test=# GRANT UNLIMITED TABLESPACE TO TEST;GRANT ROLE

drop user cascade級聯刪除語句

建立測試庫,和測試表


當有連線登陸到資料庫中時,是不允許刪除的,這與Oracle類似,可以透過如下命令確認:

\c test
lightdb@test=# select * from lt_stat_activity where datname = 'test';-[ RECORD 1 ]----+-----------------------------------datid            | 24485
datname          | test
pid              | 29451
leader_pid       | 
usesysid         | 24486
usename          | test
application_name | ltsql
client_addr      | 10.0.4.4
client_hostname  | 
client_port      | 32429
backend_start    | 2023-02-17 09:19:04.632679+08
xact_start       | 
query_start      | 2023-02-17 09:21:30.590778+08
state_change     | 2023-02-17 09:21:30.592998+08
wait_event_type  | Client
wait_event       | ClientRead
state            | idle
backend_xid      | 
backend_xmin     | 
query_id         | 5903824519346358151
query            | insert into test_table values (1);
backend_type     | client backend
lightdb@test=# drop user test cascade;ERROR:  user 'test' cannot be dropped cascade because there are users already connected.

中斷此連結後,可以cascade方式刪除

\c test
lightdb@test=# drop user test cascade;DROP ROLE

注:級聯刪除不會刪除庫


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29990276/viewspace-2935692/,如需轉載,請註明出處,否則將追究法律責任。

相關文章