java prepare_Java数据库连接PreparedStatement的使用详解

本文介绍了Java数据库连接PreparedStatement的使用详解,分享给大家,具体如下:

首先了解Statement和PreparedStatement的区别:

2be6b07d66de6668548f0b658f4f5870.png

由此可见,一般使用PreparedStatement。

操作数据库SU(Course表),其中Course属性有Cno,Cname,Cpno,Ccredit。

public class Demo_2 {

public static void main(String[] args) {

PreparedStatement ps=null;

ResultSet rs=null;

Connection ct=null;

try {

//1.加载驱动

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

//2.得到连接

ct=DriverManager.getConnection("jdbc:odbc:mytest");

//3.创建PreparedStatement

ps=ct.prepareStatement("select * from Course where Cno=? and Cpno=?");

ps.setString(1,"3"); //给第一个问号赋值

ps.setInt(2,1);

rs=ps.executeQuery();

while(rs.next()){

String Cno=rs.getString(1);

String Cname=rs.getString(2);

int Cpno=rs.getInt(3);

int Ccredit=rs.getInt(4);

System.out.println(Cno+" "+Cname+" "+Cpno+" "+Ccredit);

}

//使用 PreparedStatement添加一条记录

// ps=ct.prepareStatement("insert into Course values(?,?,?,?)");

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

// ps.setString(2, "C++");

// ps.setInt(3, 3);

// ps.setInt(4, 2);

// //执行

// int i=ps.executeUpdate();

// if(i==1){

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

// }else{

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

// }

} catch (Exception e) {

e.printStackTrace();

}finally{

try {

if(rs!=null){

rs.close();

}

if(ps!=null){

ps.close();

}

if(ct!=null){

ct.close();

}

} catch (Exception e) {

e.printStackTrace();

}

}

}

}

运行程序,控制台输出符合条件的数据。

最后总结如下:

PreparedStatement 使用crud

1. PreparedStatement可以提高执行的效率(因为它有预编译的功能)

2. PreparedStatement可以防止sql注入,但是要求?赋值的方式才可以。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值