通过JDBC进行简单的增删改查.docx
《通过JDBC进行简单的增删改查.docx》由会员分享,可在线阅读,更多相关《通过JDBC进行简单的增删改查.docx(14页珍藏版)》请在冰豆网上搜索。
通过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。
具体转化规则应该和数据库有关。