浅谈JDBC连接数据库步骤
创始人
2024-04-18 05:31:21
0

JDBC连接数据库步骤一.加载驱动

导入jar包

Class.forName("driver")

作用:不只是创建一个类的Class对象,它加载了整相关程序的类。

JDBC连接数据库步骤二.获取连接对象

Connectioncon=DriverManager.getConnection(url,user,pwd)

url:告诉数据库的位置

JDBC连接数据库步骤三.创建语句对象,执行SQL

增删改

返回影响所有行

非查询

  1. Statement:  
  2. Statementst=con.CreateStatement()  
  3. inti=st.executeUpdate(sql) 

下标从一开始

  1. inti=st.executeUpdate(sql);  
  2. PreparedStatement:  
  3. PreparedStatementps=con.PreparedStatement("sql语句")  
  4. ps.setXXX(n,值) 

对第n个?进行赋值

区别

用st的好处

在动态组装SQL时,指动态产生要执行SQL语句

用pst的好处

更好维护

避免SQL注入

效率更高

扩展

用JDBC的批处理(BATCH)可以提高效率

用ResultSetMetadata可以获取列的信息(个数,名称)

查询

  1. resultsetrs=pst.executePuery()  
  2. while(rs.net())  
  3. Stringstr=rs.getString(列的位置,列的名称) 

JDBC连接数据库步骤四.关闭

顺序

  1. ifrs!=nullrs.close();  
  2. pst.close();  
  3. con.close(); 

具体实例:

  1. privatefinalStringURL="jdbc:mysql://localhost:3306/db";  
  2. privatefinalStringFINDALL="select*fromdept";  
  3. privateConnectioncon;  
  4. privatePreparedStatementps;  
  5. privateResultSetrs;  
  6.  
  7. //查询  
  8. publicListfindAll(){  
  9. Listlist=newArrayList();  
  10. try{  
  11. Class.forName("com.mysql.jdbc.Driver");  
  12. con=DriverManager.getConnection(URL,"root","123");  
  13. ps=con.prepareStatement(FINDALL);  
  14. rs=ps.executeQuery();  
  15. while(rs.next()){  
  16. DeptDTOdto=newDeptDTO();  
  17. dto.setDeptId(rs.getInt("deptId"));  
  18. dto.setName(rs.getString("depName"));  
  19. dto.setPhone(rs.getString("phone"));  
  20. System.out.println(dto.getDeptId()+""+dto.getName()+""+dto.getPhone());  
  21. list.add(dto);  
  22. }  
  23. con.close();  
  24. }catch(ClassNotFoundExceptione){  
  25. //TODOAuto-generatedcatchblock  
  26. e.printStackTrace();  
  27. }catch(SQLExceptione){  
  28. //TODOAuto-generatedcatchblock  
  29. e.printStackTrace();  
  30. }  
  31.  
  32. returnlist;  
  33. }  
  34.  
  35.  
  36.  
  37. //添加,添加中关闭连接的方法相比查询中的关闭方法更好一些  
  38. publicvoidadd(DeptDTOdto){  
  39. try{  
  40. Class.forName("com.jdbc.mysql.Driver");  
  41. con=DriverManager.getConnection("jdbc:mysql://localhost:3306/db","root","123");  
  42. ps=con.prepareStatement("insertintodept(deptId,depName,phone)values(?,?,?)");  
  43. ps.setInt(1,dto.getDeptId());  
  44. ps.setString(2,dto.getName());  
  45. ps.setString(3,dto.getPhone());  
  46. ps.execute();  
  47. }catch(ClassNotFoundExceptione){  
  48. //TODOAuto-generatedcatchblock  
  49. e.printStackTrace();  
  50. }catch(SQLExceptione){  
  51. //TODOAuto-generatedcatchblock  
  52. e.printStackTrace();  
  53. }  
  54. finally{  
  55. try{  
  56. if(con!=null&&!con.isClosed()){  
  57. con.close();  
  58. }  
  59. }catch(SQLExceptione){  
  60. //TODOAuto-generatedcatchblock  
  61. e.printStackTrace();  
  62. }  
  63.  
  64. }  
  65.  
  66. }  
  67. le.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:35)  
  68. atoracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:801)  
  69. atjava.sql.DriverManager.getConnection(UnknownSource)  
  70. atjava.sql.DriverManager.getConnection(UnknownSource)  
  71. attool.DbConnect.getConnect(DbConnect.java:45)  
  72. attool.DbConnect.main(DbConnect.java:54

【编辑推荐】

  1. 谈谈优化JDBC数据库编程
  2. 实例说明对MySQL的JDBC连接设置
  3. 浅谈如何利用JSP网页中JDBC代码连接MySQL
  4. 浅谈JDBC代码如何重复使用
  5. 如何进行Jython数据库插入(JDBC)

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...