ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

JDBC

2021-09-05 21:01:08  阅读:162  来源: 互联网

标签:JDBC String getString rs bundle sql con


JBDC六步骤:

1.注册驱动

(1)Class.forName(driver)

(2)DriverManager.registerDriver(new com.mysql.jdbc.Driver())

(3)资源绑定器 

   ResourceBundle bundle=ResourceBundle.getBundle("文件名没有后缀")   以properties结尾的

  bundle.getString(key)

2.获取连接 DriverManager.getConnection(url,usr,password,)

3.获取数据库操作对象 createStatement

4.执行SQL语句(executeUpdate(sql)和executeQuery(sql))

5.处理查询结果集 while循环

5.释放资源(从小到大)

import java.sql.*;
import java.util.ResourceBundle;

public class JDBCDEMO {
    public static void main(String[] args) {
        Connection con=null;
        Statement st=null;
        //使用资源绑定器,先拿出properties
        ResourceBundle bundle = ResourceBundle.getBundle("jdbc"); //不用带后缀
        String driver = bundle.getString("driver");
        String url = bundle.getString("url");
        String usr = bundle.getString("usr");
        String password = bundle.getString("password");


        //1.注册驱动
        try {
//            (1) Class.forName("com.mysql.jdbc.Driver");
//            (2)DriverManager.registerDriver(new com.mysql.jdbc.Driver());
            Class.forName(driver);



        //2.获取连接
//            String url="jdbc:mysql://127.0.0.1:3306/bjpowernode";
//            String usr="root";
//            String password="123456";
//          Connection con = DriverManager.getConnection(url, usr, password);   释放资源需要分开写
            con = DriverManager.getConnection(url, usr, password);

        //3.创建数据库对象
//            Statement st = con.createStatement();   //释放资源需要分开写
            st = con.createStatement();
            
        //4.执行SQL语句
            //DML
//            String sql="INSERT into dept(deptno,dname,loc) VALUES (50,'sdsds','uuuuuuuu') ";
//            int conut = st.executeUpdate(sql);  //返回值是一个整形表示执行成功几条语句

            //DQL
            String sql="select ename,empno,sal from emp";
            ResultSet rs = st.executeQuery(sql);

        //5.处理查询结果集
            while (rs.next()){
                //按下标取出,程序不健壮
//                String ename = rs.getString(1);
//                String empno = rs.getString(2);
//                String sal = rs.getString(3);

                String ename = rs.getString("ename");
                int empno = rs.getInt("empno");   //可以全用String类型,但也可以使用固定的格式
                double sal = rs.getDouble("sal");
                System.out.println(ename+" "+empno+" "+sal); //如果是Int型等等可以做运算,例如(sal+100)
            }


        } catch (Exception e) {
            e.printStackTrace();
        } finally {
        //6.释放资源从小到大
            if (st!=null){
                try {
                    st.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            if(con!=null){
                try {
                    con.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

 

标签:JDBC,String,getString,rs,bundle,sql,con
来源: https://www.cnblogs.com/zyl777/p/15230824.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有