您好,登錄后才能下訂單哦!
前言
尷尬:access denied for user 'root'@'localhost' using password yes
有時(shí)候,在連接 MySQL 數(shù)據(jù)的時(shí)候,會(huì)報(bào)一個(gè)錯(cuò)誤信息 "access denied for user 'root'@'localhost' using password yes"
,看到這個(gè)錯(cuò)誤不要一臉懵逼,造成錯(cuò)誤的原因就是數(shù)據(jù)庫訪問的用戶名或密碼不正確,這時(shí)候一般又分為以下兩種情況,分別說一說解決方法。
一、新安MySQL未設(shè)置密碼,這種情況就需要添加密碼,如何添加?
1、用空密碼方式使用root用戶登錄 MySQL
mysql -u root
2、修改root用戶的密碼:
mysql>update 數(shù)據(jù)庫名稱 set password=PASSWORD('新的密碼') where USER='root' mysql>flush privileges; mysql>quit
3、重新啟動(dòng)MySQL,就可以使用新密碼登錄了
二、好久不用,忘記密碼
1、打開DOS進(jìn)入mysql下bin目錄:本人:D:\Development\mysql-5.5.29-winx64\bin
2、停止mysql服務(wù),net stop mysql
3、在D:\Development\mysql-5.5.29-winx64\bin 后面輸入:
mysqld --defaults-file="D:\Development\mysql-5.5.29-winx64\bin\my.ini" --console --skip-grant-tables
4、重新打開一個(gè)DOS窗口,在D:\Development\mysql-5.5.29-winx64\bin后面輸入:mysql -root -p
5、提示輸入密碼,在Enter后面輸入密碼,進(jìn)入mysql>
6、在mysql>下輸入:
mysql>update 數(shù)據(jù)庫名稱 set password=PASSWORD('新的密碼') where USER='root' mysql>flush privileges; mysql>quit
注意:若有多個(gè)數(shù)據(jù)庫可多次update操作即可。
通過屬性文件來配置MySQL
一、常見的連接數(shù)據(jù)的方式
二、屬性文件(.properties)配置與讀取
1、配置文件users.properties
jdbc.drivers=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/databaseName jdbc.username=root jdbc.password=upassword
2、讀取屬性文件
(1) 創(chuàng)建Properties的對(duì)象;
Properties properties = new Properties();
這一步也可以這樣做:創(chuàng)建繼承Properties的類,并以單例模式獲取對(duì)象。
(2) 使用Class對(duì)象的getResourceAsStream()方法,把指定的屬性文件讀入到輸入流中,并使用Properties類中的load()方法,從輸入流中讀取屬性列表(鍵/值對(duì));
private String resource = "users.properties"; //假如配置文件名為users.properties InputStream in = getClass().getResourceAsStream(resource); properties.load(in);
(3) 在使用數(shù)據(jù)庫連接時(shí),使用Properties類中的getProperty()方法,通過key獲取value值,從而實(shí)現(xiàn)數(shù)據(jù)庫連接的操作。
String drivers = props.getProperty("jdbc.drivers"); String url = props.getProperty("jdbc.url"); String username = props.getProperty("jdbc.username"); String password = props.getProperty("jdbc.password"); //返回的是Connection類的實(shí)例 Class.forName(drivers); return DriverManager.getConnection(url, username, password);
MySQL連接池
一、為什么使用數(shù)據(jù)源和連接池
應(yīng)用程序需要頻繁的連接數(shù)據(jù)庫的,如果每次操作都連接數(shù)據(jù)庫,然后關(guān)閉,這樣做性能一定會(huì)受限。所以,一定要想辦法復(fù)用數(shù)據(jù)庫的連接。使用連接池可以達(dá)到復(fù)用數(shù)據(jù)庫連接的目的。
二、連接池概念
連接池是用來管理Connection 對(duì)象的,連接池可以從數(shù)據(jù)源中獲得連接,連接池中可以有若干個(gè)數(shù)據(jù)庫連接對(duì)象,這些連接對(duì)象可以被重用。應(yīng)用程序需要連接時(shí),就向連接池申請(qǐng),如果連接池中有空閑的連接,就會(huì)分配給應(yīng)用程序,如果沒有,可能就需要在等待隊(duì)列里等待。
三、MySQL連接池配置
1、把數(shù)據(jù)庫驅(qū)動(dòng)包 以及JSTL的jar包 copy 到 %CATALINA_HOME%\lib 下。
2、修改 %CATALINA_HOME%\conf\server.xml 文件,在 <Host> 節(jié)點(diǎn)下添加:
<!-- appName 為項(xiàng)目名 docBase一定要準(zhǔn)確 &符號(hào)要換成&--!> <Context path="/appName" docBase="appName\WebRoot" auth="Container"> <Resource name="jdbc/MySQLDS" scope="Shareable" type="javax.sql.DataSource" url="jdbc:mysql://localhost:3306/kqxt?useUnicode=true&characterEncoding=utf-8" driverClassName="com.mysql.jdbc.Driver" username="root" password="root" maxWait="3000" maxIdle="100" maxActive="10" /> </Context>
3、修改 web.xml,在 <web-app> 節(jié)點(diǎn)下添加下面內(nèi)容
<resource-ref> <description>Mysql Datasource example</description> <res-ref-name>MySQLDS</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref>
4、在代碼中獲取數(shù)據(jù)庫連接
// 注意導(dǎo)入的包名 import java.sql.Connection; import javax.naming.Context; import javax.naming.InitialContext; import javax.sql.DataSource; public class DBUtil { public static Connection getConnection() throws Exception { Context context = new InitialContext(); // 獲取數(shù)據(jù)源 DataSource ds = (DataSource) context.lookup("java:comp/env/jdbc/MySQLDS"); // 獲取數(shù)據(jù)庫連接 Connection conn = ds.getConnection(); if (conn != null && !conn.isClosed()) { return conn; } else { return null; } } }
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。