mysql數據庫密碼加密步驟(mysql數據庫的密碼)

本文目錄一覽:

如何利用MySQL數據庫自帶加密函數進行加密

首先,先介紹下加密函數,PASSWORD(string)函數可以對字符串string進行加密,代碼如下:

SELECT PASSWORD(‘you’);

如下圖所示:

執行第一步的SQL語句,查詢結果是一串字符串,並且PASSWORD(string)函數加密是不可逆轉,

如下圖所示:

另外一個加密函數MD5(string),主要針對普通的數據進行加密,代碼如下:

SELECT MD5(‘hai’);

如下圖所示:

最後一個加密函數ENCODE(string,pass),可以使用字符串pass來加密字符串string。首先要創建一個數據庫表t_pass_info,代碼如下:

CREATE TABLE t_pass_info(

id int(10),

pass_info blob

);

如下圖所示:

然後,向這個數據庫表插入一條數據,代碼如下:

INSERT INTO t_pass_info(id,pass_info) VALUES

(1,ENCODE(‘dong’,’bb’));

如下圖所示:

6

查看插入數據庫表t_pass_info記錄,代碼如下:

SELECT * FROM

t_pass_info;

如下圖所示:

7

MySQL自帶還有一個解密函數DECODE(str,pass_str),可以使用字符串pass_str來為str解密,代碼如下:

SELECT DECODE(ENCODE(‘dong’,’aa’),’aa’);

如下圖所示:

mysql數據庫密碼加密方式有幾種

MySQL數據庫的認證密碼有兩種方式,

MySQL 4.1版本之前是MySQL323加密,MySQL 4.1和之後的版本都是MySQLSHA1加密,

MySQL數據庫中自帶Old_Password(str)和Password(str)函數,它們均可以在MySQL數據庫里進行查詢,前者是MySQL323加密,後者是MySQLSHA1方式加密。

(1)以MySQL323方式加密

select  old_password(‘111111’);

(2)以MySQLSHA1方式加密

select password(‘111111’);

MYSQL323加密中生成的是16位字符串,而在MySQLSHA1中生存的是41位字符串,其中*是不加入實際的密碼運算中,通過觀察在很多用戶中都攜帶了”*”,在實際破解過程中去掉”*”,也就是說MySQLSHA1加密的密碼的實際位數是40位。

mysql 密碼加密

1.mysqladmin -uxxx -p password “newpassword”;

這個方法win下不好用

2.進入mysql後

set password for ‘用戶名’@’hostname’ identified by ‘newpassword’;

3.進入mysql後

grant usage on *.* to ‘用戶名’@’hostname’ identified by ‘newpassword’;

4.修改user表

use mysql;

update user set password=password(‘newpassword’) where user=’xxxx’;

如何在mysql數據庫中加入加密算法,使得數據庫能夠對數據庫中的數據進行加密。

沒有用過mysql加密,但一般都是用服務端語言把數據加密後存入數據庫中,比如,在PHP里用md5函數把用戶的密碼加密之後存入數據中,一般都 是這麼解決的。

在MySQL數據庫中如何為用戶設置密碼

假如你是一個管理員, 你還要進行一些用戶的建立及授權,這又涉及到設置密碼的問題.下面我們就討論一下如何設置密碼: 首先我們應該知道Mysql數據庫中的口令存儲必須用password()函數加密它.因為在user表中是以加密形式存儲口令,而不是作為純文本.如果你沒有加密,直接在數據庫中執行以下語句: use mysql insert into user (host,user,password) values (‘%’,’user_name’,’your password’); flush privileges;相信結果不會讓你滿意.因為服務器比較的是加密的值,所以服務器連接一定失敗.這裡需要說明的是flush privileges;這條 命令起到了重新加載授權表.你也可以在shell下直接用mysqladmin -u root reload或者mysqladmin -u root flush-privileges來 實現重載授權表. 在MySQL環境下,你可以使用以下語句進行設置密碼: 1.insert into user(host,user,password) values(‘%’,’user_name’,password(“your password”); 2.set password for user_name = password(“your password”)以上兩種方法都必須進行重載授權表. 3.當然你也可以在創建一個用戶時直接設置密碼,grant語句將為你自動加密口令. 示例: grant all on *.* to mailto:user_name@ identified by “your password”;另外大家也可以在shell環境下用mysqladmin程序來設置密碼。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/249882.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 17:12
下一篇 2024-12-12 17:12

相關推薦

  • 如何修改mysql的端口號

    本文將介紹如何修改mysql的端口號,方便開發者根據實際需求配置對應端口號。 一、為什麼需要修改mysql端口號 默認情況下,mysql使用的端口號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python 常用數據庫有哪些?

    在Python編程中,數據庫是不可或缺的一部分。隨着互聯網應用的不斷擴大,處理海量數據已成為一種趨勢。Python有許多成熟的數據庫管理系統,接下來我們將從多個方面介紹Python…

    編程 2025-04-29
  • openeuler安裝數據庫方案

    本文將介紹在openeuler操作系統中安裝數據庫的方案,並提供代碼示例。 一、安裝MariaDB 下面介紹如何在openeuler中安裝MariaDB。 1、更新軟件源 sudo…

    編程 2025-04-29
  • Python初學者指南:第一個Python程序安裝步驟

    在本篇指南中,我們將通過以下方式來詳細講解第一個Python程序安裝步驟: Python的安裝和環境配置 在命令行中編寫和運行第一個Python程序 使用IDE編寫和運行第一個Py…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL數據庫 在使用Python操作MySQL之前,我們需要先連接MySQL數據庫。在Python中,我…

    編程 2025-04-29
  • 數據庫第三範式會有刪除插入異常

    如果沒有正確設計數據庫,第三範式可能導致刪除和插入異常。以下是詳細解釋: 一、什麼是第三範式和範式理論? 範式理論是關係數據庫中的一個規範化過程。第三範式是範式理論中的一種常見形式…

    編程 2025-04-29
  • MySQL遞歸函數的用法

    本文將從多個方面對MySQL遞歸函數的用法做詳細的闡述,包括函數的定義、使用方法、示例及注意事項。 一、遞歸函數的定義 遞歸函數是指在函數內部調用自身的函數。MySQL提供了CRE…

    編程 2025-04-29
  • 正五邊形畫法步驟圖解

    正五邊形是一種經典的幾何圖形,其獨特的構造方式給它帶來了無限的美感和藝術價值。本篇文章將從多個方面詳細闡述正五邊形的畫法步驟圖解,幫助您輕鬆get到繪製正五邊形的竅門。 一、構造正…

    編程 2025-04-29
  • leveldb和unqlite:兩個高性能的數據庫存儲引擎

    本文將介紹兩款高性能的數據庫存儲引擎:leveldb和unqlite,並從多個方面對它們進行詳細的闡述。 一、leveldb:輕量級的鍵值存儲引擎 1、leveldb概述: lev…

    編程 2025-04-28
  • MySQL bigint與long的區別

    本文將從數據類型定義、存儲空間、數據範圍、計算效率、應用場景五個方面詳細闡述MySQL bigint與long的區別。 一、數據類型定義 bigint在MySQL中是一種有符號的整…

    編程 2025-04-28

發表回復

登錄後才能評論