通过JDBC进行简单的增删改查.docx

上传人:b****7 文档编号:9118883 上传时间:2023-02-03 格式:DOCX 页数:14 大小:106.18KB
下载 相关 举报
通过JDBC进行简单的增删改查.docx_第1页
第1页 / 共14页
通过JDBC进行简单的增删改查.docx_第2页
第2页 / 共14页
通过JDBC进行简单的增删改查.docx_第3页
第3页 / 共14页
通过JDBC进行简单的增删改查.docx_第4页
第4页 / 共14页
通过JDBC进行简单的增删改查.docx_第5页
第5页 / 共14页
点击查看更多>>
下载资源
资源描述

通过JDBC进行简单的增删改查.docx

《通过JDBC进行简单的增删改查.docx》由会员分享,可在线阅读,更多相关《通过JDBC进行简单的增删改查.docx(14页珍藏版)》请在冰豆网上搜索。

通过JDBC进行简单的增删改查.docx

通过JDBC进行简单的增删改查

通过JDBC进行简单的增删改查(以MySQL为例)

目录

前言:

什么是JDBC

一、准备工作

(一):

MySQL安装配置和基础学习

二、准备工作

(二):

下载数据库对应的jar包并导入

三、JDBC基本操作

(1)定义记录的类(可选)

(2)连接的获取

(3)insert

(4)update

(5)select

(6)delete

四、测试

五、代码分析

六、思考问题

 

 

前言:

什么是JDBC

  维基百科的简介:

  Java数据库连接,(JavaDatabaseConnectivity,简称JDBC)是Java语言中用来规范客户端程序如何来访问数据库的应用程序接口,提供了诸如查询和更新数据库中数据的方法。

JDBC也是SunMicrosystems的商标。

它JDBC是面向关系型数据库的。

  简单地说,就是用于执行SQL语句的一类JavaAPI,通过JDBC使得我们可以直接使用Java编程来对关系数据库进行操作。

通过封装,可以使开发人员使用纯JavaAPI完成SQL的执行。

 

一、准备工作

(一):

MySQL安装配置和基础学习

  使用JDBC操作数据库之前,首先你需要有一个数据库。

这里提供了3个链接供读者自学,如果曾有过SQL语言的使用经历(包括在学校中的课堂学习),前两个链接足以上手。

  1.安装和配置:

mysql安装图解mysql图文安装教程(详细说明)

  2.基本操作:

21分钟MySQL入门教程

  3.简易命令查询:

一千行MySQL学习笔记

 

  建议边看入门教程,边练习,在练习insert、update、select、delete等基本操作的同时,将后面要用的表建好。

  下图是我接下来用于演示的数据库的表。

    

 

二、准备工作

(二):

下载数据库对应的jar包并导入

  使用JDBC需要在工程中导入对应的jar包。

数据库与JDBC包的对应关系可以参考各种数据库对应的jar包、驱动类名和URL格式。

在Eclipse下的导入方法:

  在工程的图标上右击,选择”Properties”,在”JavaBulidPath”中选择”AddExternalJARs…”,选择下载并解压后获得的jar包。

     

  如果对MySQL进行操作,这时下面的import就不会报错了:

importcom.mysql.jdbc.Connection;

importcom.mysql.jdbc.PreparedStatement;

  除此以外,还需要JDBC的包,直接import即可。

importjava.sql.DriverManager;

importjava.sql.ResultSet;

importjava.sql.SQLException;

 

三、JDBC基本操作

  为了简单起见,与数据库相关的操作、命令、参数都被硬编码了。

有兴趣的读者可以对这些进行探索,降低数据与操作的耦合性。

  先看具体代码并实践,本文第五部分对用到的API稍作了研究。

  下面的所有方法和数据成员都在publicclassJDBCOperation内部。

(1)定义记录的类(可选)

  这样做主要是为了便于操作和接口定义,是非必须的。

staticclassStudent{

privateStringId;

privateStringName;

privateStringSex;

privateStringAge;

Student(StringName,StringSex,StringAge){

this.Id=null;//default

this.Name=Name;

this.Sex=Sex;

this.Age=Age;

}

publicStringgetId(){

returnId;

}

publicvoidsetId(StringId){

this.Id=Id;

}

publicStringgetName(){

returnName;

}

publicvoidsetName(StringName){

this.Name=Name;

}

publicStringgetSex(){

returnSex;

}

publicvoidsetSex(StringSex){

this.Sex=Sex;

}

publicStringgetAge(){

returnAge;

}

publicvoidsetage(StringAge){

this.Age=Age;

}

}

 

(2)连接的获取

  在操作前必须先获取与数据库的连接。

  driver、url的格式同样可以参考各种数据库对应的jar包、驱动类名和URL格式。

privatestaticConnectiongetConn(){

Stringdriver="com.mysql.jdbc.Driver";

Stringurl="jdbc:

mysql:

//localhost:

3306/samp_db";

Stringusername="root";

Stringpassword="";

Connectionconn=null;

try{

Class.forName(driver);//classLoader,加载对应驱动

conn=(Connection)DriverManager.getConnection(url,username,password);

}catch(ClassNotFoundExceptione){

e.printStackTrace();

}catch(SQLExceptione){

e.printStackTrace();

}

returnconn;

}

 

(3)insert

privatestaticintinsert(Studentstudent){

Connectionconn=getConn();

inti=0;

Stringsql="insertintostudents(Name,Sex,Age)values(?

?

?

)";

PreparedStatementpstmt;

try{

pstmt=(PreparedStatement)conn.prepareStatement(sql);

pstmt.setString(1,student.getName());

pstmt.setString(2,student.getSex());

pstmt.setString(3,student.getAge());

i=pstmt.executeUpdate();

pstmt.close();

conn.close();

}catch(SQLExceptione){

e.printStackTrace();

}

returni;

}

 

(4)update

privatestaticintupdate(Studentstudent){

Connectionconn=getConn();

inti=0;

Stringsql="updatestudentssetAge='"+student.getAge()+"'whereName='"+student.getName()+"'";

PreparedStatementpstmt;

try{

pstmt=(PreparedStatement)conn.prepareStatement(sql);

i=pstmt.executeUpdate();

System.out.println("resutl:

"+i);

pstmt.close();

conn.close();

}catch(SQLExceptione){

e.printStackTrace();

}

returni;

}

 

(5)select

  以select*fromXXX为例。

privatestaticIntegergetAll(){

Connectionconn=getConn();

Stringsql="select*fromstudents";

PreparedStatementpstmt;

try{

pstmt=(PreparedStatement)conn.prepareStatement(sql);

ResultSetrs=pstmt.executeQuery();

intcol=rs.getMetaData().getColumnCount();

System.out.println("============================");

while(rs.next()){

for(inti=1;i<=col;i++){

System.out.print(rs.getString(i)+"\t");

if((i==2)&&(rs.getString(i).length()<8)){

System.out.print("\t");

}

}

System.out.println("");

}

System.out.println("============================");

}catch(SQLExceptione){

e.printStackTrace();

}

returnnull;

}

 

(6)delete

privatestaticintdelete(Stringname){

Connectionconn=getConn();

inti=0;

Stringsql="deletefromstudentswhereName='"+name+"'";

PreparedStatementpstmt;

try{

pstmt=(PreparedStatement)conn.prepareStatement(sql);

i=pstmt.executeUpdate();

System.out.println("resutl:

"+i);

pstmt.close();

conn.close();

}catch(SQLExceptione){

e.printStackTrace();

}

returni;

}

 

四、测试

  在测试前,需要在系统中打开对应数据库的服务。

MySQL在Windows下的启动命令为

netstartmysql

 

  测试代码

publicstaticvoidmain(Stringargs[]){

JDBCOperation.getAll();

JDBCOperation.insert(newStudent("Achilles","Male","14"));

JDBCOperation.getAll();

JDBCOperation.update(newStudent("Bean","","7"));

JDBCOperation.delete("Achilles");

JDBCOperation.getAll();

}

 

  Eclipse中的输出

============================

1Endermale8

2Beanmale6

3Petrafema9

4Petermale9

5_Graffmale40

6GODfema255

============================

============================

1Endermale8

2Beanmale6

3Petrafema9

4Petermale9

5_Graffmale40

6GODfema255

7AchillesMale14

============================

resutl:

1

resutl:

1

============================

1Endermale8

2Beanmale7

3Petrafema9

4Petermale9

5_Graffmale40

6GODfema255

============================

 

五、代码分析

  在上述对数据库进行增删改查的过程中,可以发现其共性部分,即通用的流程:

  

(1)创建Connection对象、SQL查询命令字符串;

  

(2)对Connection对象传入SQL查询命令,获得PreparedStatement对象;

  (3)对PreparedStatement对象执行executeUpdate()或executeQurey()获得结果;

  (4)先后关闭PreparedStatement对象和Connection对象。

  可见,使用JDBC时,最常打交道的是Connection、PreparedStatement这两个类,以及select中的ResultSet类。

查阅JavaAPI手册可以了解其具体的意义和方法。

  下面引用的JavaAPI的资料出自

  

  Connection

java.sql 

接口Connection

所有超级接口:

Wrapper

publicinterfaceConnectionextendsWrapper

 

与特定数据库的连接(会话)。

在连接上下文中执行SQL语句并返回结果。

Connection 对象的数据库能够提供描述其表、所支持的SQL语法、存储过程、此连接功能等等的信息。

此信息是使用 getMetaData 方法获得的。

 

  PreparedStatemnt

java.sql 

接口PreparedStatement

所有超级接口:

Statement, Wrapper

所有已知子接口:

CallableStatement

publicinterfacePreparedStatementextendsStatement

表示预编译的SQL语句的对象。

SQL语句被预编译并存储在 PreparedStatement 对象中。

然后可以使用此对象多次高效地执行该语句。

 

常用方法

 boolean execute()

         在此PreparedStatement对象中执行SQL语句,该语句可以是任何种类的SQL语句。

 ResultSet executeQuery()

         在此PreparedStatement对象中执行SQL查询,并返回该查询生成的ResultSet对象。

 int executeUpdate()

         在此PreparedStatement对象中执行SQL语句,该语句必须是一个SQL数据操作语言(DataManipulationLanguage,DML)语句,比如INSERT、UPDATE或DELETE语句;或者是无返回内容的SQL语句,比如DDL语句。

  

  ResultSet

  

java.sql 

接口ResultSet

所有超级接口:

Wrapper

所有已知子接口:

CachedRowSet, FilteredRowSet, JdbcRowSet, JoinRowSet, RowSet, SyncResolver, WebRowSet

publicinterfaceResultSetextendsWrapper

表示数据库结果集的数据表,通常通过执行查询数据库的语句生成。

  

六、思考问题

1.每次SQL操作都需要建立和关闭连接,这势必会消耗大量的资源开销,如何避免?

分析:

可以采用连接池,对连接进行统一维护,不必每次都建立和关闭。

事实上这是很多对JDBC进行封装的工具所采用的。

 

2.Java代码中,传入的数据格式与数据库定义不同怎么办?

如把Java的String对象赋值给数据库的tinyint属性。

分析:

在执行SQL语句时,数据库会尝试进行转换。

根据我的实验,如果用内容为纯字母的String对象传入tinyint的age属性时,会被转化成0。

具体转化规则应该和数据库有关。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 解决方案 > 工作计划

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1