JDBC中三大执行SQL命令的Statement对象
1个回答
展开全部
简介:
1、Statement
2、PreparedStatement
3、CallableStetement
CallableStatement 对象为所有的 DBMS 提供了一种以标准形式调用已储存过程的方法。已储存过程储存在数据库中。对已储存过程的调用是 CallableStatement 对象所含的内容。这种调用是用一种换码语法来写的,有两种形式:一种形式带结果参数,另一种形式不带结果参数。结果参数是一种输出 (OUT) 参数,是已储存过程的返回值。两种形式都可带有数量可变的输入(IN 参数)、输出(OUT 参数)或输入和输出(INOUT参数)的参数。问号将用作参数的占位符。
关系:
Statement是PreparedStatement父类;
PreparedStatement是CallableStetement的父类。
语法:
1、Statement语法
2、PreparedStatement语法
PreparedStatement perstmt=null;
perstmt =con.prepareStatement("insert into tb_name (col1,col2,col2,col4) values(?,?,?,?)");//通过数据库连接对象的方法获得
perstmt.setString(1,var1);//给占位符赋值,var1~var4是已赋值的变量
perstmt.setString(2,var2);//1、2、3、4是占位符(?)的编号
perstmt.setString(3,var3);
perstmt.setString(4,var4);
perstmt.executeUpdate();//执行SQL语句
3、CallableStetement语法
CallableStatement proc=null;//创建对象
String sql=” {call getPageCount(?)} ”;//编写SQL命令
//获取数据库连接conn
proc=conn.parepareCall(sql);//调用存储过程
procCall.registerOutParameter(1,Types.INTEGER);//转化数据类型
procCall.execute();//执行SQL命令
newsTotalCount = procCall.getInt(1);//获取存储过程的OUT参数
1、Statement
2、PreparedStatement
3、CallableStetement
CallableStatement 对象为所有的 DBMS 提供了一种以标准形式调用已储存过程的方法。已储存过程储存在数据库中。对已储存过程的调用是 CallableStatement 对象所含的内容。这种调用是用一种换码语法来写的,有两种形式:一种形式带结果参数,另一种形式不带结果参数。结果参数是一种输出 (OUT) 参数,是已储存过程的返回值。两种形式都可带有数量可变的输入(IN 参数)、输出(OUT 参数)或输入和输出(INOUT参数)的参数。问号将用作参数的占位符。
关系:
Statement是PreparedStatement父类;
PreparedStatement是CallableStetement的父类。
语法:
1、Statement语法
2、PreparedStatement语法
PreparedStatement perstmt=null;
perstmt =con.prepareStatement("insert into tb_name (col1,col2,col2,col4) values(?,?,?,?)");//通过数据库连接对象的方法获得
perstmt.setString(1,var1);//给占位符赋值,var1~var4是已赋值的变量
perstmt.setString(2,var2);//1、2、3、4是占位符(?)的编号
perstmt.setString(3,var3);
perstmt.setString(4,var4);
perstmt.executeUpdate();//执行SQL语句
3、CallableStetement语法
CallableStatement proc=null;//创建对象
String sql=” {call getPageCount(?)} ”;//编写SQL命令
//获取数据库连接conn
proc=conn.parepareCall(sql);//调用存储过程
procCall.registerOutParameter(1,Types.INTEGER);//转化数据类型
procCall.execute();//执行SQL命令
newsTotalCount = procCall.getInt(1);//获取存储过程的OUT参数
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询