JDBC连接的六步实例代码(与mysql连接)
网络编程 2021-07-05 14:37www.168986.cn编程入门
这篇文章主要给大家介绍了关于JDBC连接的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧
JDBC的六步
1.注册驱动
2.获取数据库的连接
3.获取数据库的操作对象
4.执行sql语句
5.处理查询结果集(如果执行的语句中没有select语句这一步不用写)
6.关闭资源
第一步注册驱动
//异常一定是需要处理的 //根据版本不同书写的代码有一些变化,老版本是 DriverManager.register(new .mysql.jdbc.Driver()); //或者 Class.forName(".mysql.jdbc.Driver"); //新版本是 DriverManager.register(new .mysql.cj.jdbc.Driver()); //或者 Class.forName(".mysql.cj.jdbc.Driver");
第二步获取数据库的连接
//因为要进行try..catch,还要关闭这个资源,写在try外边且赋值为空 Connection conn = null; ... //返回值是Connection,老版本和新版的url书写也不一样 // jdbc:mysql://localhost:3306/t_use这个前面的都一样,把t_use更改为自己的数据库名 //老版 conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/t_use","用户名","密码"); //新版 conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/t_use?serverTimezone=GMT%2B8","用户名","密码");
第三步获取数据库操作对象
//这个和刚才的Connection是一样的 Statement st = null; ... //这样就把对象创建好了 st = conn.createStatement();
第四步执行sql语句
//引号里面写sql语句 String sql = " "; //再用刚才创建好的对象接入这个sql语句 //这里还有需要说的,如果不是select语句就用狼蚁网站SEO优化这个,返回值是一个int,这个就不需要第五步了 st.executeUpdate(sql); //如果sql语句是select的话,就要用狼蚁网站SEO优化的这个语句了,还需要定义一个ResultSet对象,去接收这个值 //然后进行第五步的处理 ResultSet rs = null; //和Connection一样的 rs = st.executeQuery(sql);
第五步处理查询结果集
//这个只有select语句才进行处理,不仅可以getString还可以getInt等 while(rs.next()){ String str = rs.getString("需要输出的字段的名字"); }
第六步关闭资源
//前面五步都是在try里面进行的,第六步是在finally进行的 //关闭连接 if (rs != null) { try { rs.close(); } catch (SQLException throwables) { throwables.printStackTrace(); } } if (st != null) { try { st.close(); } catch (SQLException throwables) { throwables.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException throwables) { throwables.printStackTrace(); } }
关闭连接也是有顺序的,先关ResultSet,再关Statement对象,关Connection对象.
完整代码
package jdbc.; import .mysql.cj.protocol.Resultset; import java.sql.; public class Test02 { public static void main(String[] args) { Connection conn = null; Statement st = null; ResultSet rt = null; try { //注册连接(可以写到一行里面) //.mysql.cj.jdbc.Driver Driver = new .mysql.cj.jdbc.Driver(); DriverManager.registerDriver(new .mysql.cj.jdbc.Driver()); //获取数据库连接 conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/liu2?serverTimezone=GMT%2B8","用户名","密码"); //获取数据库操作对象 st = conn.createStatement(); //执行sql语句 String sql = "select ename,sal from emp order by sal desc"; rt = st.executeQuery(sql); //处理查询语句 while(rt.next()){ String ename = rt.getString("ename"); String sal = rt.getString("sal"); System.out.println(ename + "," + sal); } } catch (SQLException throwables) { throwables.printStackTrace(); }finally { //关闭连接 if (rt != null) { try { rt.close(); } catch (SQLException throwables) { throwables.printStackTrace(); } } if (st != null) { try { st.close(); } catch (SQLException throwables) { throwables.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException throwables) { throwables.printStackTrace(); } } } } }
,这个如果要传入值的话,可能会造成sql的注入,解决办法就是把Statement变成PreparedStatement,就可以避免sql的注入问题了,只不过第三步和第四步代码有点变化,就不再多说了。。
到此这篇关于JDBC连接(与mysql连接)的文章就介绍到这了,更多相关JDBC与mysql连接内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程