前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Java Web之MySQL在项目中的使用

Java Web之MySQL在项目中的使用

作者头像
YungFan
发布于 2018-05-03 06:58:57
发布于 2018-05-03 06:58:57
1K00
代码可运行
举报
文章被收录于专栏:学海无涯学海无涯
运行总次数:0
代码可运行
尴尬:access denied for user ’root’@’localhost’ using password yes

有时候,在连接 MySQL 数据的时候,会报一个错误信息 "access denied for user ’root’@’localhost’ using password yes",看到这个错误不要一脸懵逼,造成错误的原因就是数据库访问的用户名或密码不正确,这时候一般又分为以下两种情况,分别说一说解决方法。

一、新安MySQL未设置密码,这种情况就需要添加密码,如何添加? 1、用空密码方式使用root用户登录 MySQL

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql -u root

2、修改root用户的密码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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>下输入:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
jdbc.drivers=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/databaseName
jdbc.username=root
jdbc.password=upassword

2、读取属性文件

(1) 创建Properties的对象;

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Properties properties = new Properties();

这一步也可以这样做:创建继承Properties的类,并以单例模式获取对象。

(2) 使用Class对象的getResourceAsStream()方法,把指定的属性文件读入到输入流中,并使用Properties类中的load()方法,从输入流中读取属性列表(键/值对);

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
private String resource = "users.properties";
//假如配置文件名为users.properties
InputStream in = getClass().getResourceAsStream(resource);
properties.load(in);

(3) 在使用数据库连接时,使用Properties类中的getProperty()方法,通过key获取value值,从而实现数据库连接的操作。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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> 节点下添加:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!-- 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> 节点下添加下面内容

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<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、在代码中获取数据库连接

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 注意导入的包名
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;
            }
      }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017.06.26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Tomcat 6 JNDI数据源详解
数据库连接池这个概念应该都不陌生,在Java中连接池也就是数据库的连接池,它是一种采用连接复用的思想避免多次连接造成资源的浪费机制。 最常见的连接池就是DBCP和C30P了,在tomcat中默认使用
用户1154259
2018/01/17
9410
Tomcat 6 JNDI数据源详解
C3P0连接池配置和实现详解「建议收藏」
一、C3P0配置 c3p0的配置方式分为三种,分别是 1.setters一个个地设置各个配置项 2.类路径下提供一个c3p0.properties文件 3.类路径下提供一个c3p0-config.xml文件
全栈程序员站长
2022/06/30
2.2K0
tomcat5配置常见数据库连接池的例子.
环境: w2kp sp4, jsdk1.4.2_8; tomcat5.0.2.8; oracle817, sqlserver2000 sp3 , mysql5 beta
jack.yang
2025/04/05
820
Druid连接池的基本配置与使用
Druid是阿里巴巴的开源连接池组件,是世界上最好的连接池之一。Druid能对数据库连接进行有效管理和重用,最大化程序执行的效率。连接池负责创建和管理连接,程序只负责取用与归还。
害恶细君
2022/11/22
2.2K0
Druid连接池的基本配置与使用
tomcat配置数据库连接池
数据库连接池是干啥的我就不用多少了,从名字上就可以看的出来(A:我看不出来。B:去看百科:http://baike.baidu.com/view/84055.htm)。因此在这就说一下简单的配置经过。
the5fire
2019/02/28
4.2K0
数据库连接池、dbutil_知识点全掌握
数据库连接池、dbutil 数据库连接池 1 数据库连接池的概念 用池来管理Connection,这可以重复使用Connection。有了池,所以我们就不用自己来创建Connection,而是通过池来
Java帮帮
2018/03/19
8100
数据库连接池、dbutil_知识点全掌握
Confluence 6 新 Confluence 安装配置一个数据源连接
如果在你的 Tomcat 中配置了数据源,并且Confluence 设置指南在安装的时候检测到这个配置的时候,配置数据源的选项将会提供给你进行配置。入股你希望使用数据源,请参考下面的配置。
HoneyMoose
2019/01/31
1.2K0
数据源及分层开发
Java Naming and Directory Interface,Java命名和目录接口
xiaozhangStu
2023/05/04
3590
Java Web JDBC数据源
在tomcat中配置数据库连接池 在tomcat中的conf文件下:context.xml配置文件中配置 代码: <?xml version='1.0' encoding='utf-8'?> <!--
Hongten
2018/09/13
4540
tomcat7中配置c3p0数据库连接池 原
参考的是:http://bioubiou.iteye.com/blog/1776589和http://bbs.csdn.net/topics/390708897
克虏伯
2019/04/15
9450
tomcat7中配置c3p0数据库连接池
                                                                            原
线程池实现原理_最通俗易懂的解读比特币相关原理
本篇内容综合广大网友提供内容,笔者经过整理,对数据库连接池原理和实现过程做个很系统的并且通俗易懂的分析讲解,以及手写一个连接池实现过程作为演示。
全栈程序员站长
2022/09/29
2930
线程池实现原理_最通俗易懂的解读比特币相关原理
tomcat数据源配置
配置webRoot/WEB-INF/aurora.database/datasource.config文件:
栋先生
2018/09/29
3.4K0
tomcat数据源配置
JavaWeb14-事务,连接池(Java正在的全栈开发)
事务&连接池 一.事务 1. 事务介绍 什么是事务 事务,一般是指要做的或所做的事情。在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元。这些单元要么全都成功,要么全都不成功。 事务
Java帮帮
2018/03/19
8690
JavaWeb14-事务,连接池(Java正在的全栈开发)
Java JDBC 编程指北
在我们日常使用的 APP 或网站中,往往需要存取数据,比如在微信中,需要存储我们的用户名、手机号、用户密码…… 等一系列信息。依靠之前所学习的 Java 相关知识已经无法满足这一需求。现在的应用程序中最基本、应用最广的也就是关系型数据库,如 MySQL。Java 语言中为了实现与关系型数据库的通信,制定了标准的访问捷克,即 JDBC(Java Database Connectivity)。本文主要介绍在 Java 中使用 JDBC 的相关知识,主要内容如下:
村雨遥
2021/05/08
6630
Java JDBC 编程指北
4. MyBatis核心配置文件详解
如果类的根路径下有一个包叫做test,CarMapper.xml如果放在test包下的话,这个配置应该是这样写:
捞月亮的小北
2024/06/22
1030
4. MyBatis核心配置文件详解
Driud数据库连接池的使用
上面是比较官方的介绍,解释起来还是蛮简单的,就是构建起一个池子,然后把经常需要用的对象放到里面,然后每次调用的时候,就直接取出来就可以了,不需要再次new一个,这样可以节约很多时间。
GeekLiHua
2025/01/21
1240
Driud数据库连接池的使用
mybatis核心配置文件解读
● configuration:根标签,表示配置信息。 ● environments:环境(多个),以“s”结尾表示复数,也就是说mybatis的环境可以配置多个数据源。 ○ default属性:表示默认使用的是哪个环境,default后面填写的是environment的id。default的值只需要和environment的id值一致即可。 ● environment:具体的环境配置(主要包括:事务管理器的配置 + 数据源的配置) ○ id:给当前环境一个唯一标识,该标识用在environments的default后面,用来指定默认环境的选择。 ● transactionManager:配置事务管理器 ○ type属性:指定事务管理器具体使用什么方式,可选值包括两个 ■ JDBC:使用JDBC原生的事务管理机制。底层原理:事务开启conn.setAutoCommit(false); ...处理业务...事务提交conn.commit(); ■ MANAGED:交给其它容器来管理事务,比如WebLogic、JBOSS等。如果没有管理事务的容器,则没有事务。没有事务的含义:只要执行一条DML语句,则提交一次。 ● dataSource:指定数据源 ○ type属性:用来指定具体使用的数据库连接池的策略,可选值包括三个 ■ UNPOOLED:采用传统的获取连接的方式,虽然也实现Javax.sql.DataSource接口,但是并没有使用池的思想。 ● property可以是: ○ driver 这是 JDBC 驱动的 Java 类全限定名。 ○ url 这是数据库的 JDBC URL 地址。 ○ username 登录数据库的用户名。 ○ password 登录数据库的密码。 ○ defaultTransactionIsolationLevel 默认的连接事务隔离级别。 ○ defaultNetworkTimeout 等待数据库操作完成的默认网络超时时间(单位:毫秒) ■ POOLED:采用传统的javax.sql.DataSource规范中的连接池,mybatis中有针对规范的实现。 ● property可以是(除了包含UNPOOLED中之外): ○ poolMaximumActiveConnections 在任意时间可存在的活动(正在使用)连接数量,默认值:10 ○ poolMaximumIdleConnections 任意时间可能存在的空闲连接数。 ○ 其它.... ■ JNDI:采用服务器提供的JNDI技术实现,来获取DataSource对象,不同的服务器所能拿到DataSource是不一样。如果不是web或者maven的war工程,JNDI是不能使用的。 ● property可以是(最多只包含以下两个属性): ○ initial_context 这个属性用来在 InitialContext 中寻找上下文(即,initialContext.lookup(initial_context))这是个可选属性,如果忽略,那么将会直接从 InitialContext 中寻找 data_source 属性。 ○ data_source 这是引用数据源实例位置的上下文路径。提供了 initial_context 配置时会在其返回的上下文中进行查找,没有提供时则直接在 InitialContext 中查找。 ● mappers:在mappers标签中可以配置多个sql映射文件的路径。 ● mapper:配置某个sql映射文件的路径 ○ resource属性:使用相对于类路径的资源引用方式 ○ url属性:使用完全限定资源定位符(URL)方式
一个风轻云淡
2023/09/24
1990
Java Review(三十四、JDBC)
JDBC指Java 数据库连接,是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库。
三分恶
2020/07/16
7770
JNDI数据库连接池
JNDI的全称是java命名与目录接口(Java Naming and Directory Interface),是一个应用程序设计的API,为开发人员提供了查找和访问各种命名和目录服务的通用、统一的接口。我们可以把JNDI简单地理解为是一种将对象和名字绑定的技术,即指定一个资源名称,将该名称与某一资源或服务相关联,当需要访问其他组件和资源时,就需要使用JNDI服务进行定位,应用程序可以通过名字获取对应的对象或服务。 JNDI方式 - 配置Tomcat6.0 连接池 数据库连接池的基本思想就是为数据库连
汤高
2018/01/11
2.2K0
第二十七天 数据库基础&JDBC使用&工具类Properties&连接池&DBUtils【悟空教程】
第二十七天 数据库基础&JDBC使用&工具类Properties&连接池&DBUtils【悟空教程】
Java帮帮
2018/07/27
7600
第二十七天 数据库基础&JDBC使用&工具类Properties&连接池&DBUtils【悟空教程】
相关推荐
Tomcat 6 JNDI数据源详解
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文