中阶d03.2 JDBC联合properties使用,通过读取本地配置文件为代码传递参数
- * 使用properties读取本地配置文件为代码传递参数
- * url、用户名、密码、驱动地址等配置可以在配置文件中使用
- main
- package zj_1_JDBC.properties;
- import java.sql.Connection;
- import java.sql.ResultSet;
- import java.sql.Statement;
- /*
- * 使用properties读取本地配置文件为代码传递参数
- * url、用户名、密码、驱动地址等配置可以在配置文件中使用
- *
- * 编辑工具类,整合 注册驱动和释放资源 方法。
- * */
- public class MainTest2 {
- public static void main(String[] args) {
- Connection conn = null;
- Statement st = null;
- ResultSet rs = null;
- //注册驱动
- conn = JDBCUtil_properties.getConn();
- try {
- //创建statement , 跟数据库打交道
- st = conn.createStatement();
- //执行查询 , 得到结果集
- String sql = "select * from users";
- rs = st.executeQuery(sql);
- //遍历查询每一条记录
- while (rs.next()) {
- int id = rs.getInt("id");
- String name = rs.getString("name");
- int age = rs.getInt("age");
- }
- } catch (Exception e) {
- e.printStackTrace();
- }finally {
- //释放资源
- JDBCUtil_properties.closeRelease(conn,st,rs);
- }
- }
- }
- JDBCUtil_properties
- package zj_1_JDBC.properties;
- import java.io.*;
- import java.sql.*;
- import java.util.Properties;
- /*
- *创建Properties对象,通过读取本地配置文件为代码传递参数。
- *
- *
- * Properties实现了Map接口,可以使用k,v键值对存储数据
- *Properties具有一些操作io流的内置方法
- *
- * Properties和IO流结合的功能:
- void load(Reader reader)读字符数据
- void list(PrintWriter out)写字符数据
- *
- * */
- public class JDBCUtil_properties {
- static String driverClass = null;
- static String url = null;
- static String username = null;
- static String password= null;
- static{
- try {
- //创建属性配置对象Properties
- Properties properties = new Properties();
- InputStream is = new FileInputStream("jdbc.properties");
- //使用类加载器,去读取src底下的资源文件。 后面在servlet
- //InputStream is = JDBCUtil.class.getClassLoader().getResourceAsStream("jdbc.properties");
- //导入输入流
- properties.load(is);
- //读取属性
- driverClass = properties.getProperty("driverClass");
- url = properties.getProperty("url");
- username = properties.getProperty("name");
- password = properties.getProperty("password");
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- //获取连接对象
- public static Connection getConn() {
- Connection conn = null;
- try {
- Class.forName(driverClass);
- conn = DriverManager.getConnection(url,url,password);
- } catch (Exception e) {
- e.printStackTrace();
- }
- return conn;
- }
- //释放资源
- public static void closeRelease(Connection conn , Statement st , ResultSet rs) {
- closeRs(rs);
- closeSt(st);
- closeConn(conn);
- }
- private static void closeRs(ResultSet rs) {
- try {
- if(rs != null) {
- rs.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }finally {
- rs = null;
- }
- }
- private static void closeSt(Statement st) {
- try {
- if(st != null) {
- st.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }finally {
- st = null;
- }
- }
- private static void closeConn(Connection conn) {
- try {
- if(conn != null) {
- conn.close();
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }finally {
- conn = null;
- }
- }
- }
- jdbc.properties
- driverClass=com.mysql.jdbc.Driver
- url=jdbc:mysql://localhost/student
- name=root
- password=root
输出
中阶d03.2 JDBC联合properties使用,通过读取本地配置文件为代码传递参数的更多相关文章
- 中阶d03 JDBC 使用
1.首先在数据库中创建表 2.安装mysql驱动 java开发环境中导入jdbc连接mysql的jar包 mysql-connector-java-5.1.7-bin.jar 下载地址:https:/ ...
- 中阶d03.4 JDBC_DAO
1.环境准备(单项目下用,在大jdbc项目下只用配置一次) jdbc的驱动(mysqlxxjdbc.jar).util工具(包装释放资源.建立连接.访问properties文件等方法) 2.dao的概 ...
- 中阶 d03.5 (正篇)完整的Dao 操作数据库
1.目录结构: util---JDBCUtil.java(工具包,整合建立链接和释放资源的方法) dao---UserDao.java(接口,定义方法) impl---UserDaoImpl.java ...
- 中阶d03.1 JDBCDemo
1. jdbc使用查看驱动的doc文档<connector-j.html> 2.代码实现:1. 注册驱动---2. 建立连接---3. 创建statement ,跟数据库打交道--- -- ...
- 中阶d03.3 JDBC_CURD_Util --- 使用 junit执行单元测试(增删改查)
1.单元测试环境准备 https://www.cnblogs.com/longesang/p/11399010.html 2.测试 3.结果返回 4.代码 新建一个test目录统一存放测试案例 查: ...
- jsp中利用response.senddirect(str)重定向,传递参数新思路
用Servlet进行请求重定向,参数传递好办,直接用request.setAttribute(str1,str2); 但是如果不用Servlet 而是直接用jsp进行转发呢? 我们首先要知道 请求 ...
- jsp中四种传递参数的方法
jsp中四种传递参数的方法如下: 1.form表单 2.request.setAttribute();和request.getAttribute(); 3.超链接:<a herf="i ...
- (转)JSP中四种传递参数的方法:
1.form表单 2.request.setAttribute();和request.getAttribute(); 3.超链接:<a herf="index.jsp"?a= ...
- BMP是在Bean中完成对数据库JDBC的各种调用
BMP是在Bean中完成对数据库JDBC的各种调用 CMP是由EJB容器自动完成对数据库的操作 会话Bean主要处理业务逻辑
随机推荐
- Jasper报表 自动序列号
添加表达式:$V{REPORT_COUNT}.toString()
- MyBatis框架——多表查询
MyBatis多表查询, 从表中映射主表,使用 association 标签,通过设置 javaType 属性关联实体类: 主表映射从表,使用 collection 标签,通过 ofType 属性关联 ...
- iOS开发:判断iPhone是否是刘海屏iPhoneX、iPhoneXR、iPhoneXs、iPhoneXs Max等
保证能判断,呕心沥血,不行切JIJI 方法一 Objective-C // iPhoneX.iPhoneXR.iPhoneXs.iPhoneXs Max等 // 判断刘海屏,返回YES表示是刘海屏 - ...
- Mol Cell Proteomics. | Proteomics Analysis of Extracellular Matrix Remodeling During Zebrafish Heart Regeneration (解读人:徐宁)
文献名:Proteomics Analysis of Extracellular Matrix Remodeling During Zebrafish Heart Regeneration(斑马鱼心脏 ...
- The instance of entity type 'manager' cannot be tracked because another instance with the same key value for {'id'} is already being tracked. When attaching existing entities, ensure that only one ent
最近在用ASP.NET CORE时遇到一些问题,现记录下: 出现上述错误,即在更新实体数据时出现的错误 services.AddDbContext<StoreContext>(c => ...
- 全国职业技能大赛信息安全管理与评估-第三阶段-弱口令自动爆破+读取Flag脚本
自动爆破SSH弱口令+读取Flag #coding=utf-8 import paramiko sshc = paramiko.SSHClient() sshc.set_missing_host_ke ...
- Java并发编程之支持并发的list集合你知道吗
Java并发编程之-list集合的并发. 我们都知道Java集合类中的arrayList是线程不安全的.那么怎么证明是线程不安全的呢?怎么解决在并发环境下使用安全的list集合类呢? 本篇是<凯 ...
- Django 支付宝付款接口的使用
我们在开发的过程中经常会碰到调用微信或者支付宝接口进行付款,付款完成之后,如果用户绑定了我的账号,我只要有活动了,就要给这个关注我的用户推动消息,让用户知道,比如说,我们经常会关注一些公众号,然后这些 ...
- 理解卷积神经网络中的输入与输出形状(Keras实现)
即使我们从理论上理解了卷积神经网络,在实际进行将数据拟合到网络时,很多人仍然对其网络的输入和输出形状(shape)感到困惑.本文章将帮助你理解卷积神经网络的输入和输出形状. 让我们看看一个例子.CNN ...
- Fiddler抓取数据包分析案例
案例:利用Fiddler抓取苏宁易购网站数据包分析 抓包软件:Fiddler4 请求名字:www.suning.com 详细内容: 一.了解数据包区域的字段含义 图1数据包区域 #:顺序号,按照抓包的 ...