`
jandroid
  • 浏览: 1935422 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

JDBC入门学习

 
阅读更多

JDBC笔记

一、CURD介绍

是指在计算处理时的增加(create)、查询(retrieve)(重新得到数据)、更新、和删除几个音讯的首写字母的简写。主要是用在描述软件系统中数据库或者持久层的基本操作功能。

二、JDBC基本概念

JDBC(JavaDataBaseConnectivity,Java数据库连接)是一种用于执行SQL语句的JAVAAPI。可以为多种关系数据库提供统一访问。它由一组用JAVA语言编写的类和接中组成。JDBC为工具/数据库开发人员提供了一个标准API,据此,可以构建更高级的工具和接口。使数据库开发人员能够用纯JAVAAPI编写数据库应用程序。同时,JDBC也是一个商标名。

三、JDBC驱动的分类

目前较为常见的JDBC驱动程序可以分为以下四类:

1.JDBC-ODBC桥连接

2.本地协议纯JAVA驱动程序

3.网络协议纯JAVA驱动程序

4.本地API

1JDBC-ODBC桥连接方式操作数据库

A、配置数据源

控制面板à管理工具à数据源(ODBCà用户DSN添加àSQLServerà完成à输入名称描述服务器(.代表本机)à选择一种登录模式à下一步à更改默认数据库à完成à测试

B、在程序中连接数据源

四步曲:

1、加载驱动

2、得到数据源

3、创建Statement或者PreparedStatement

4、执行CRUD

/**

*演示:JDBC-ODBC桥连接操作数据库

*1、配置数据源

*2、在程序中连接数据源

*/

packageclass16.test1;

importjava.sql.DriverManager;

importjava.sql.SQLException;

importjava.sql.*;

publicclassJDBCDemo01{

publicstaticvoidmain(String[]args)throwsSQLException{

Connectionct=null;

Statementsm=null;

try{

//1.加载驱动

Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

//2.得到连接。指定数据源。登录名,密码

ct=DriverManager

.getConnection("jdbc:odbc:Mytest","sa","123456");

//3.创建Statement或者PreparedStatement

//用处:主要是用于发送SQL语句

sm=ct.createStatement();

//插入记录

//inti=

//sm.executeUpdate("insertintoCoursevalues('010','JDBC','2','12-601')");

//if(i==1){

//System.out.println("添加成功");

//}

//else{

//System.out.println("添加失败");

//}

////删除记录

//inti=sm.executeUpdate("deletefromCoursewherecno='010'");

//

//if(i==1){

//System.out.println("删除成功");

//}

//else{

//System.out.println("删除失败");

//}

//修改记录

// inti=sm

// .executeUpdate("updateCoursesetcredit=3wherecno='009'");

//

// if(i==1){

// System.out.println("更新成功");

// }else{

// System.out.println("更新失败");

// }

//executeQuery()查询返回一个ResultSet结果集

ResultSetrs=sm.executeQuery("select*fromCourse");

//因为rs是指向结果集中的第一行的前一行,可循环取出

while(rs.next()){

Stringcno=rs.getString(1);//列号根据数据类型取出相应的类型

Stringcname=rs.getString(2);

intcredit=rs.getInt(3);

Stringclassroom=rs.getString(4);

System.out.printf(cno+"/t"+cname+"/t"+credit+"/t"+classroom+"/n"); }

}catch(Exceptione){

e.printStackTrace();

}finally{//关闭资源,后创建先关闭

if(sm!=null){//加个if是为了让程序变得分健壮一些

sm.close();

}

if(ct!=null){

ct.close();

}

}

}

}

四、StatementPreparedStatement的区别:

StatementPreparedStatement都可以用于把SQL语句从JAVA程序中发送到指定数据库,并执行SQL语句,但他们也存在差别

a)直接使用Statement,驱动程序一般不会对SQL语句作处理,而是直接交给数据使用PreparedStatement形成一个预编译的过程,并且会对语句作字符集的转换(至少在SQLSERVER)中如此。

如此,有两个好处:对于多次重复执行的语句,使用PreparedStatement效率会更高一点。并且在这种情况下比较适合使用批处理,另外,可以比较好地解决系统的本地化问题

b)PreparedStatement还能有效的防止危险字符的注入,也就是SQL注入

SQLSERVER中存在这样一种select*fromdbo.Coursewherecno='0320'or1='1'的危险语句。加上or1='1'前面条件怎么乱写都会出结果

预编译的解释

/**

*演示:用PreparedStatement执行操作数据库

*

*PreparedStatement的好处:执行查询效率高。

*能有效的防止危险字符的注入但需要使用?机制

*/

packageclass16.test1;

importjava.sql.*;

publicclassJDBCDemo02{

publicstaticvoidmain(String[]args){

Connectionct=null;

ResultSetrs=null;

PreparedStatementps=null;

try{

//1.加载驱动

Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

//2.得到连接

ct=DriverManager.getConnection("jdbc:odbc:Mytest","sa","123456");

//3.创建PreparedStatement对象

// //演示查询

// ps=ct.prepareStatement("select*fromCoursewherecno=?");

// ps.setString(1,"001");//可以对多个?赋值

// rs=ps.executeQuery();//执行查询

// while(rs.next()){//遍历结果集

// Stringcno=rs.getString(1);//列号

// Stringcname=rs.getString(2);

// intcredit=rs.getInt(3);

// Stringclassroom=rs.getString(4);

// System.out.printf(cno+"/t"+cname+"/t"+credit+"/t"+classroom+"/n");

// }

//演示插入

// ps=ct.prepareStatement("insertintoCoursevalues(?,?,?,?)");

// ps.setString(1,"011");

// ps.setString(2,"JDBC");

// ps.setInt(3,2);

// ps.setString(4,"3-301");

//演示删除

ps=ct.prepareStatement("deletefromCoursewherecno=?");

ps.setString(1,"010".trim());

inti=ps.executeUpdate();

if(i==1){

System.out.println("删除成功");

}

else{

System.out.println("删除失败");

}

}catch(Exceptione){

e.printStackTrace();

}

finally{//关闭资源

if(ps!=null){

try{

ps.close();

}catch(SQLExceptione){

e.printStackTrace();

}

} if(ct!=null){

try{

ct.close();

}catch(SQLExceptione){

e.printStackTrace();

}

}

}

}

}

2JDBC连接方式

首先要加入JAR

四步曲:

1、加载驱动

2、得到连接

3、创建Statement或者PreparedStatement

4、执行CRUD

几个不同:

加载驱动方式的不同:

Class.forName(com.microsoft.sqlserver.jdbc.SQLServerDriver)

得到连接方式不同:

Connection ct=DriverManager.getConnection("jdbc:sqlserver://PC-201006071344:1433;databaseName=Ch03","sa","123456");

代码如下:

packageclass18.test1;

importjava.sql.Connection;

importjava.sql.DriverManager;

importjava.sql.PreparedStatement;

importjava.sql.ResultSet;

publicclassJDBCDemo03{

publicstaticvoidmain(String[]args){

Connectionct=null;

ResultSetrs=null;

PreparedStatementps=null;

try{

//加载驱动

Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");

//得到连接 ct=DriverManager.getConnection("jdbc:sqlserver://PC-201006071344:1433;databaseName=Ch03","sa","123456");

ps=ct.prepareStatement("select*fromCourse");

rs=ps.executeQuery();

while(rs.next()){

Stringcno=rs.getString(1);

Stringcname=rs.getString(2);

intcredit=rs.getInt(3);

Stringclassroom=rs.getString(4);

System.out.printf(cno+"/t"+cname+"/t"+credit+"/t"+classroom+"/n");

}

}catch(Exceptione){

e.printStackTrace();

}

finally{//关闭资源

try{

if(ps!=null)ps.close();

if(ct!=null)ct.close();

}catch(Exceptione2){

//TODO:handleexception

}

}

}

}

分享到:
评论

相关推荐

    JDBC基础学习

    ### JDBC基础学习精要 JDBC,全称为Java Database Connectivity,是Java中一项重要的技术,旨在为各种关系型数据库提供统一的访问接口。通过一组由Java语言编写的类和接口,JDBC允许开发者以一致的方式操作不同的...

    JDBC入门学习简单教程

    1. JDK 1.1 - JDBC 1.0:这是JDBC的基础版本,提供了基本的数据库连接功能。 2. JDK 1.2, 1.3 - JDBC 2.0:增加了更多的功能和接口,如PreparedStatement和CallableStatement,同时在J2EE环境中引入了javax.sql包。 ...

    JDBC基础.ppt

    **JDBC基础学习目标:** 1. **理解Java中的数据库连接**:了解Java如何通过JDBC API与各种类型的数据库(如关系型、面向对象关系型和面向对象数据库)建立连接。 2. **掌握JDBC API**:熟悉java.sql包中的核心类和...

    JDBC 基础入门

    **JDBC基础入门详解** Java Database Connectivity(JDBC)是Java平台中用于与数据库交互的一组接口和类,它是Java标准API的一部分,使得Java开发者能够访问各种类型的数据库系统。本篇将详细介绍JDBC的基础知识,...

    JDBC 入门电子书.zip

    **JDBC 入门知识详解** Java Database Connectivity (JDBC) 是Java编程语言中用于与各种类型数据库交互的标准API。它是Java平台的核心部分,由Java SE的Java SQL类库提供,使得开发者能够编写数据库独立的代码,...

    JDBC Hibernate学习笔记

    通过对JDBC和Hibernate的学习,我们不仅了解了如何使用Java与数据库进行交互的基础知识,还深入探讨了如何利用ORM框架简化数据访问层的开发工作。JDBC提供了与数据库交互的低级API,而Hibernate则是在JDBC基础上构建...

    JDBC基础(入门级的)

    **JDBC基础知识详解** Java Database Connectivity (JDBC) 是Java平台上的一个标准API,用于与关系型数据库进行交互。它是Java开发者访问数据库的唯一、统一的接口,由Sun Microsystems(现已被Oracle收购)定义,...

    jdbc入门至精通

    【jdbc入门至精通】 在Java开发中,JDBC(Java Database Connectivity)是连接Java应用程序与各种数据库的关键技术。本文将从基础概念出发,逐步深入,帮助读者从入门到精通JDBC。 **第二节 jdbc的概念** 2.1 **...

    详细标准的jdbc学习资料

    通过本套学习资料,你可以系统地了解和掌握JDBC的使用,包括建立连接、执行SQL、处理结果、事务处理、批处理和优化技巧等,为实际的数据库操作打下坚实的基础。资料分为四个部分,分别从初级到高级逐步深入,从day1...

    JDBC入门(学习课件1)

    **JDBC入门(学习课件1)** Java Database Connectivity(JDBC)是Java语言中用于与各种数据库进行交互的一种标准接口。它由Sun Microsystems(现已被Oracle收购)开发,是Java平台的标准部分,允许Java应用程序...

    达内jdbc学习笔记

    总的来说,"达内jdbc学习笔记"涵盖了JDBC基础、数据库连接、SQL执行、结果集处理、事务管理和性能优化等多个关键知识点,对Java开发者来说是宝贵的参考资料。通过深入学习和实践,可以熟练地使用Java进行数据库操作...

    JDBC入门基础讲座

    **JDBC入门基础讲座** Java Database Connectivity(JDBC)是Java平台中用于与关系数据库进行交互的一种标准API。它是Java编程语言的一部分,允许程序员使用Java语言来访问和处理各种数据库。JDBC提供了一组接口和...

    java(jdbc)学习

    ### Java JDBC 学习知识点详述 #### 一、JDBC 概念及与应用程序的关系 JDBC(Java Database Connectivity)是一种用于执行SQL语句的Java API,它为数据库开发人员提供了一种标准的API来访问多种类型的数据库,无论...

    非常好的JDBC学习文档

    总的来说,这个"非常好的JDBC学习文档"将涵盖从基础到进阶的JDBC知识,包括驱动管理、连接创建、SQL执行、事务处理、异常控制、批处理以及连接池的使用。通过学习,你不仅可以掌握数据库操作,还能理解如何在实际...

    JDBC(学习课件)

    在实际开发中,学习JDBC通常包括以下步骤: 1. 加载驱动:通过`Class.forName()`方法加载数据库驱动。 2. 建立连接:使用`DriverManager.getConnection()`方法,传入数据库URL、用户名和密码来创建连接。 3. 创建...

    JAVA数据库接口JDBC入门基础讲座

    **Java数据库接口JDBC入门基础讲座** 在Java编程领域,JDBC(Java Database Connectivity)是连接Java应用程序与各种类型数据库的重要桥梁。它提供了一套标准的API,使得开发者能够使用Java语言来操作数据库,实现...

    JSP JDBC 学习笔记(基础)

    在学习过程中,阅读提供的"jsp 基础教程.doc", "jsp学习 笔记.doc", "JDBC 笔记.doc", "jsp 笔记二.doc"文档,将有助于你深入理解JSP和JDBC的使用方法和最佳实践。这些笔记详细阐述了相关概念、示例代码和常见问题,...

    【Java学习笔记】JDBC基础篇

    jdbc基础篇教程md版:这份markdown格式的教程详细介绍了jdbc的基础概念、配置方法以及如何通过jdbc进行数据库的增删改查(crud)操作。教程内容涵盖了jdbc驱动的加载、数据库连接的建立、sql语句的执行以及结果集的...

Global site tag (gtag.js) - Google Analytics