MariaDB 10.4.11 (GA)的變化和改進

1、賬戶鎖定

支持管理員鎖定/解鎖用戶帳戶,語句:

 

1 鎖定

ALTER USER 'hechunyang'@'%' ACCOUNT LOCK;

 

當鎖定後,用戶再次登錄時,提示如下信息:

# mysql -h127.0.0.1 -uhechunyang -p -P3312

Enter password:

ERROR 4151 (HY000): Access denied, this account is locked

 

2 解鎖

ALTER USER 'hechunyang'@'%' ACCOUNT UNLOCK;

 

注:帳戶被鎖定現有連接不受影響,新的客戶端不允許連接。

 

3 查看賬戶鎖定信息

> show create user hechunyang@'%'\G;

*************************** 1. row ***************************

CREATE USER for hechunyang@%: CREATE USER 'hechunyang'@'%'

IDENTIFIED BY PASSWORD

'*1DA3AF2348DE66F7554E816DEDC1F1340814842E' ACCOUNT LOCK

 

> select * from mysql.global_priv where user='hechunyang'\G;

*************************** 1. row ***************************

Host: %

User: hechunyang

Priv:

{"access":1073740799,"plugin":"mysql_native_password","authentication_string":"*

1DA3AF2348DE66F7554E816DEDC1F1340814842E","password_last_changed":15

76823835,"account_locked":true}


2、用戶密碼到期

1 設置用戶到期時間

>CREATE USER 'hechunyang'@'%' PASSWORD EXPIRE INTERVAL 1 DAY;

 

>ALTER USER 'hechunyang'@'%' PASSWORD EXPIRE INTERVAL 1 DAY;

 

注:單位默認只有DAY(天),最小爲1天。

 

當用戶權限到期後,登錄時提示修改密碼,如下:

[email protected][(none)]>show processlist;

ERROR 1820 (HY000): You must SET PASSWORD before executing this statement

ERROR 1820 (HY000): You must SET PASSWORD before executing this statement

ERROR 1820 (HY000): You must SET PASSWORD before executing this statement

 

2 解除限制

>ALTER USER 'hechunyang'@'%' PASSWORD EXPIRE NEVER;

 

3、支持更改字符集utf8->utf8mb4採用ALGORITHM=INSTANT算法

MariaDB支持表的某一字段,或者整張表,字符集utf8轉換爲utf8mb4採用ALGORITHM=INSTANT算法(只修改字典信息)

 

例表結構:

CREATE TABLE t1 (

  id int(11) DEFAULT NULL,

  cid int(11) DEFAULT NULL,

  name varchar(60) DEFAULT NULL,

  KEY IX_cid (cid)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

 

DDL變更語句(秒級更改)

alter table t1 modify name varchar(60) charset utf8mb4, ALGORITHM=INSTANT;

 

需要注意的地方:

1)反過來utf8mb4->utf8是不支持INSTANT算法的。

2)如果你的字段是latin1拉丁文,轉utf8/utf8mb4不支持INSTANT算法的。

 

注:MySQL 8.0.18版本中,修改字符集utf8->utf8mb4是無法使用到INSTANT算法的,需要重建表(ALGORITHM=COPY算法),且會鎖表,update/delete/insert/replace into語句會被MDL鎖住(Waiting for table metadata lock


4、字段長度不大於varchar(256),支持採用ALGORITHM=INSTANT算法

例表結構:

CREATE TABLE t1 (

  id int(11) DEFAULT NULL,

  cid int(11) DEFAULT NULL,

  name varchar(60) DEFAULT NULL,

  KEY IX_cid (cid)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

 

DDL變更語句(秒級更改)

alter table t1 modify name varchar(80) DEFAULT NULL, ALGORITHM=INSTANT;

 

需要注意的地方:

1varchar(60)減少到varchar(40)是不支持INSTANT算法的。

2)大於並等於varchar(256),這裏的256是指字節(UTF8佔用3字節),是不支持INSTANT算法的。

 

注:只對varchar類型採用INSTANT算法,charint是無效的,仍舊是需要拷貝數據且鎖表。





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章