欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java Web學(xué)習(xí)之MySQL在項(xiàng)目中的使用方法

 更新時(shí)間:2018年04月29日 11:22:23   作者:YungFan  
mysql數(shù)據(jù)庫(kù)是我們?cè)谌粘i_(kāi)發(fā)中經(jīng)常會(huì)用到的,下面這篇文章主要給大家介紹了關(guān)于Java Web學(xué)習(xí)之MySQL在項(xiàng)目中的使用方法,需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

前言

尷尬: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ù)庫(kù)訪問(wèn)的用戶名或密碼不正確,這時(shí)候一般又分為以下兩種情況,分別說(shuō)一說(shuō)解決方法。

一、新安MySQL未設(shè)置密碼,這種情況就需要添加密碼,如何添加?

1、用空密碼方式使用root用戶登錄 MySQL

mysql -u root

2、修改root用戶的密碼:

mysql>update 數(shù)據(jù)庫(kù)名稱 set password=PASSWORD('新的密碼') where USER='root'
mysql>flush privileges;
mysql>quit

3、重新啟動(dòng)MySQL,就可以使用新密碼登錄了

二、好久不用,忘記密碼

1、打開(kāi)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、重新打開(kāi)一個(gè)DOS窗口,在D:\Development\mysql-5.5.29-winx64\bin后面輸入:mysql -root -p

5、提示輸入密碼,在Enter后面輸入密碼,進(jìn)入mysql>

6、在mysql>下輸入:

mysql>update 數(shù)據(jù)庫(kù)名稱 set password=PASSWORD('新的密碼') where USER='root'
mysql>flush privileges;
mysql>quit

注意:若有多個(gè)數(shù)據(jù)庫(kù)可多次update操作即可。

通過(guò)屬性文件來(lái)配置MySQL

一、常見(jiàn)的連接數(shù)據(jù)的方式

  • 編碼方式,將數(shù)據(jù)庫(kù)配置信息直接寫(xiě)入JAVA代碼之中
  • Properties屬性文件,將數(shù)據(jù)庫(kù)配置信息寫(xiě)在屬性文件中,然后在程序中讀取該屬性文件。
  • 數(shù)據(jù)源,用JNDI來(lái)獲取DataSource 對(duì)象,從而的到Connection對(duì)象。
  • 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) 創(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ù)庫(kù)連接時(shí),使用Properties類中的getProperty()方法,通過(guò)key獲取value值,從而實(shí)現(xiàn)數(shù)據(jù)庫(kù)連接的操作。

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ù)庫(kù)的,如果每次操作都連接數(shù)據(jù)庫(kù),然后關(guān)閉,這樣做性能一定會(huì)受限。所以,一定要想辦法復(fù)用數(shù)據(jù)庫(kù)的連接。使用連接池可以達(dá)到復(fù)用數(shù)據(jù)庫(kù)連接的目的。

二、連接池概念

連接池是用來(lái)管理Connection 對(duì)象的,連接池可以從數(shù)據(jù)源中獲得連接,連接池中可以有若干個(gè)數(shù)據(jù)庫(kù)連接對(duì)象,這些連接對(duì)象可以被重用。應(yīng)用程序需要連接時(shí),就向連接池申請(qǐng),如果連接池中有空閑的連接,就會(huì)分配給應(yīng)用程序,如果沒(méi)有,可能就需要在等待隊(duì)列里等待。

三、MySQL連接池配置

1、把數(shù)據(jù)庫(kù)驅(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ù)庫(kù)連接

// 注意導(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ù)庫(kù)連接
  Connection conn = ds.getConnection();
  if (conn != null && !conn.isClosed()) {
    return conn;
   } else {
    return null;
   }
  }
}

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • Java_Spring之基于注解的 AOP 配置

    Java_Spring之基于注解的 AOP 配置

    這篇文章主要介紹了Java_Spring中基于注解的AOP配置,我們要先進(jìn)行環(huán)境的搭建,在進(jìn)行注解配置,感興趣的同學(xué)可以參考閱讀
    2023-04-04
  • Java設(shè)計(jì)模式之代理模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    Java設(shè)計(jì)模式之代理模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    這篇文章主要介紹了Java設(shè)計(jì)模式之代理模式,本文詳細(xì)的介紹了什么事代理模式和相關(guān)的類和接口,有興趣的可以了解一下
    2017-08-08
  • 詳解SpringMVC中的異常處理機(jī)制

    詳解SpringMVC中的異常處理機(jī)制

    本篇文章將為大家詳細(xì)介紹一下springmvc的異常處理機(jī)制,用到了ControllerAdvice和ExceptionHandler注解,感興趣的小伙伴可以了解一下
    2022-07-07
  • Java 基于AQS實(shí)現(xiàn)一個(gè)同步器

    Java 基于AQS實(shí)現(xiàn)一個(gè)同步器

    這篇文章主要介紹了如何基于AQS實(shí)現(xiàn)一個(gè)同步器,幫助大家更好的理解和學(xué)習(xí)Java并發(fā),感興趣的朋友可以了解下
    2020-09-09
  • 在java中main函數(shù)如何調(diào)用外部非static方法

    在java中main函數(shù)如何調(diào)用外部非static方法

    這篇文章主要介紹了在java中main函數(shù)如何調(diào)用外部非static方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • 用SpringMVC編寫(xiě)一個(gè)HelloWorld的詳細(xì)過(guò)程

    用SpringMVC編寫(xiě)一個(gè)HelloWorld的詳細(xì)過(guò)程

    SpringMVC是Spring的一個(gè)后續(xù)產(chǎn)品,是Spring的一個(gè)子項(xiàng)目<BR>SpringMVC?是?Spring?為表述層開(kāi)發(fā)提供的一整套完備的解決方案,本文我們將用SpringMVC編寫(xiě)一個(gè)HelloWorld,文中有詳細(xì)的編寫(xiě)過(guò)程,需要的朋友可以參考下
    2023-08-08
  • Java如何配置IDEA自定義注釋

    Java如何配置IDEA自定義注釋

    在IDEA中設(shè)置自動(dòng)創(chuàng)建類和方法的注釋可以提高編碼效率,確保代碼的一致性和可讀性,首先,對(duì)于創(chuàng)建類的注釋,可以通過(guò)修改File→Settings→File and Code Templates→Class的模板來(lái)實(shí)現(xiàn),其次,對(duì)于方法注釋
    2024-10-10
  • Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(24)

    Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(24)

    下面小編就為大家?guī)?lái)一篇Java基礎(chǔ)的幾道練習(xí)題(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望可以幫到你
    2021-07-07
  • 實(shí)例分析Try {} Catch{} 作用

    實(shí)例分析Try {} Catch{} 作用

    本文是通過(guò)一個(gè)簡(jiǎn)單的實(shí)例,向大家介紹了Try {} Catch{}的意義和作用,非常的實(shí)用,有需要的小伙伴可以參考下。
    2015-10-10
  • Springboot中登錄后關(guān)于cookie和session攔截問(wèn)題的案例分析

    Springboot中登錄后關(guān)于cookie和session攔截問(wèn)題的案例分析

    這篇文章主要介紹了Springboot中登錄后關(guān)于cookie和session攔截案例,本文通過(guò)實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08

最新評(píng)論