c语言sscanf函数的用法是什么
201
2023-08-06
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:\DevelopmLdTATent\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");
StriLdTATng 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 文件,在
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" /> 3、修改 web.xml,在 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; } } } 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。
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" />
3、修改 web.xml,在
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;
}
}
}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~