Java Web学习之MySQL在项目中的使用方法
前言 尴尬: 有时候,在连接 MySQL 数据的时候,会报一个错误信息 一、新安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:Developmentmysql-5.5.29-winx64bin 2、停止mysql服务,net stop mysql 3、在D:Developmentmysql-5.5.29-winx64bin 后面输入: mysqld --defaults-file="D:Developmentmysql-5.5.29-winx64binmy.ini" --console --skip-grant-tables 4、重新打开一个DOS窗口,在D:Developmentmysql-5.5.29-winx64bin后面输入:mysql -root -p 5、提示输入密码,在Enter后面输入密码,进入mysql> 6、在mysql>下输入: mysql>update 数据库名称 set password=PASSWORD('新的密码') where USER='root' mysql>flush privileges; mysql>quit 注意:若有多个数据库可多次update操作即可。 通过属性文件来配置MySQL 一、常见的连接数据的方式
二、属性文件(.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%confserver.xml 文件,在 <Host> 节点下添加: <!-- appName 为项目名 docBase一定要准确 &符号要换成&--!> <Context path="/appName" docBase="appNameWebRoot" 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; } } } 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的支持。 您可能感兴趣的文章:
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |