java web mysql_Java Web之MySQL在项目中的使用

尴尬: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 文件,在 节点下添加:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值