Java Web学习之MySQL在项目中的使用方法

 更新时间:2018年04月29日 11:22:23   作者:YungFan  
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 文件,在 <Host> 节点下添加:

<!-- 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,在 <web-app> 节点下添加下面内容

<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;
   }
  }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • Java在排序数组中查找元素的第一个和最后一个位置的方法详解

    Java在排序数组中查找元素的第一个和最后一个位置的方法详解

    相信大家在操作Java的时候经常会要在一个数组(无序)中查找元素的第一个和最后一个位置,下面这篇文章主要给大家介绍了关于Java在排序数组中查找元素的第一个和最后一个位置的相关资料,需要的朋友可以参考下
    2024-01-01
  • Java中的Timer与TimerTask原理详解

    Java中的Timer与TimerTask原理详解

    这篇文章主要介绍了Java中的Timer与TimerTask原理详解,timerTask本身没什么意义,只是和timer集合操作的一个对象,实现它就必然有对应的run方法,以被调用,他甚至于根本不需要实现Runnable,需要的朋友可以参考下
    2023-07-07
  • Java实现复杂的进制转换器功能示例

    Java实现复杂的进制转换器功能示例

    这篇文章主要介绍了Java实现复杂的进制转换器功能,结合实例形式分析了java数学运算的相关实现技巧,需要的朋友可以参考下
    2017-01-01
  • SpringBoot调用公共模块的自定义注解失效的解决

    SpringBoot调用公共模块的自定义注解失效的解决

    这篇文章主要介绍了SpringBoot调用公共模块的自定义注解失效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • 基于SpringBoot和Hutool工具包实现验证码的案例

    基于SpringBoot和Hutool工具包实现验证码的案例

    随着安全性的要求越来越高,目前项目中很多都会使用验证码,只要涉及到登录,绝大多数都会有验证的要求,验证码的形式也是多种多样,更复杂的图形验证码和行为验证码已经成为了更流行的趋势,本文给大家介绍了SpringBoot Hutool实现验证码的案例,需要的朋友可以参考下
    2024-05-05
  • Spring中的ApplicationContext与BeanFactory详解

    Spring中的ApplicationContext与BeanFactory详解

    这篇文章主要介绍了Spring中的ApplicationContext与BeanFactory详解,Spring的IoC容器就是一个实现了BeanFactory接口的可实例化类,事实上, Spring提供了两种不同的容器,一种是最基本的BeanFactory,另一种是扩展的ApplicationContext,需要的朋友可以参考下
    2024-01-01
  • Springboot实现根据用户ID切换动态数据源

    Springboot实现根据用户ID切换动态数据源

    在很多具体应用场景中,我们需要用到动态数据源的情况,比如多租户的场景,系统登录时需要根据用户信息切换到用户对应的数据库。这篇文章主要介绍了SpringBoot根据用户ID实现切换动态数据源的示例代码,感兴趣的可以了解一下
    2021-12-12
  • Java设计模式之备忘录模式实现对象状态的保存和恢复

    Java设计模式之备忘录模式实现对象状态的保存和恢复

    本文介绍Java设计模式之备忘录模式,该模式可以实现对象状态的保存和恢复。通过详细讲解备忘录模式的原理、实现方法和应用场景,帮助读者深入理解该设计模式,并提供示例代码和技巧,便于读者实际应用
    2023-04-04
  • Java判断用户输入月份的季节

    Java判断用户输入月份的季节

    这篇文章主要为大家详细介绍了Java判断用户输入月份的季节,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • Java中文件读写操作与常用技巧分享

    Java中文件读写操作与常用技巧分享

    在 Java I/O 体系中,File 类是唯一代表磁盘文件本身的对象,而File 类定义了一些与平台无关的方法来操作文件,所以下面我们一起来看看 File 类有哪些操作方法吧
    2023-06-06

最新评论