Java Web之MySQL在專案中的使用

YungFan發表於2017-12-13

一個錯誤引發的尷尬:access denied for user ’root’@’localhost’ using password yes

有時候,在連線 MySQL 資料的時候,會報一個錯誤資訊 "access denied for user ’root’@’localhost’ using password yes",看到這個錯誤不要一臉懵逼,造成錯誤的原因就是資料庫訪問的使用者名稱或密碼不正確,這時候一般又分為以下兩種情況,分別說一說解決方法。

一、新安MySQL未設定密碼,這種情況就需要新增密碼,如何新增?

1、用空密碼方式使用root使用者登入 MySQL

mysql -u root
複製程式碼

2、修改root使用者的密碼:

mysql>update 資料庫名稱 set password=PASSWORD('新的密碼') where USER='root'
mysql>flush privileges;
mysql>quit
複製程式碼

3、重新啟動MySQL,就可以使用新密碼登入了

二、好久不用,忘記密碼

1、開啟DOS進入mysql下bin目錄:本人:D:\Development\mysql-5.5.29-winx64\bin
2、停止mysql服務,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、重新開啟一個DOS視窗,在D:\Development\mysql-5.5.29-winx64\bin後面輸入:mysql -root -p
5、提示輸入密碼,在Enter後面輸入密碼,進入mysql>
6、在mysql>下輸入:

mysql>update 資料庫名稱 set password=PASSWORD('新的密碼') where USER='root'
mysql>flush privileges;
mysql>quit
複製程式碼

注意:若有多個資料庫可多次update操作即可。

通過屬性檔案來配置MySQL

一、常見的連線資料的方式

  • 編碼方式,將資料庫配置資訊直接寫入JAVA程式碼之中
  • Properties屬性檔案,將資料庫配置資訊寫在屬性檔案中,然後在程式中讀取該屬性檔案。
  • 資料來源,用JNDI來獲取DataSource 物件,從而的到Connection物件。
  • Hibernate配置
  • Spring配置

二、屬性檔案(.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) 建立Properties的物件;

Properties properties = new Properties();
複製程式碼

這一步也可以這樣做:建立繼承Properties的類,並以單例模式獲取物件。

(2) 使用Class物件的getResourceAsStream()方法,把指定的屬性檔案讀入到輸入流中,並使用Properties類中的load()方法,從輸入流中讀取屬性列表(鍵/值對);

private String resource = "users.properties";
//假如配置檔名為users.properties
InputStream in = getClass().getResourceAsStream(resource);
properties.load(in);
複製程式碼

(3) 在使用資料庫連線時,使用Properties類中的getProperty()方法,通過key獲取value值,從而實現資料庫連線的操作。

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類的例項
Class.forName(drivers);
return DriverManager.getConnection(url, username, password);
複製程式碼

MySQL連線池

一、為什麼使用資料來源和連線池

應用程式需要頻繁的連線資料庫的,如果每次操作都連線資料庫,然後關閉,這樣做效能一定會受限。所以,一定要想辦法複用資料庫的連線。使用連線池可以達到複用資料庫連線的目的。

二、連線池概念

連線池是用來管理Connection 物件的,連線池可以從資料來源中獲得連線,連線池中可以有若干個資料庫連線物件,這些連線物件可以被重用。應用程式需要連線時,就向連線池申請,如果連線池中有空閒的連線,就會分配給應用程式,如果沒有,可能就需要在等待佇列裡等待。

三、MySQL連線池配置

1、把資料庫驅動包 以及JSTL的jar包 copy 到 %CATALINA_HOME%\lib 下。 2、修改 %CATALINA_HOME%\conf\server.xml 檔案,在 節點下新增:

<!-- appName 為專案名 docBase一定要準確 &符號要換成&--!>
<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,在 節點下新增下面內容

<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、在程式碼中獲取資料庫連線

// 注意匯入的包名
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();
      // 獲取資料來源
      DataSource ds = (DataSource) context.lookup("java:comp/env/jdbc/MySQLDS");
      // 獲取資料庫連線
      Connection conn = ds.getConnection();
      if (conn != null && !conn.isClosed()) {
             return conn;
         } else {
             return null;
            }
      }
}
複製程式碼

相關文章