当前位置: 首页 > 编程笔记 >

Java采用setAsciiStream方法检索数据库指定内容实例解析

鲜于德泽
2023-03-14
本文向大家介绍Java采用setAsciiStream方法检索数据库指定内容实例解析,包括了Java采用setAsciiStream方法检索数据库指定内容实例解析的使用技巧和注意事项,需要的朋友参考一下

本文实例展示了Java采用setAsciiStream()方法检索数据库的实例代码。使用参数查询必须在SQL 语句执行之前对参数进行赋值,赋值是使用PreparedStatement 对象的SetBoolean()、SetInt()、SetString()、SetObject()、SetNull()等方法来实现。这些方法建立了Java数据类型和SQL 数据类型的映射。JDBC 可以使用输入流作为SQL 语句的输入参数,设置输入流的方法有三个:setAsciiStream()、setUnicodeStream()、setBinaryStream()。本例采用了setAsciiStream()方法,此方法将ASCII 码值输入到SQL 的Longvarchar 类型的参数中。执行查询后会返回一个ResultSet 对象,该对象包括查询语句返回的存放有查询结果的表,通过使用ResultSet 对象的next()方法可以获得记录集的下一条记录。使用ResultSet 对象的getInt()、getString、getBoolean()、getByte()、getObject()等方法来获得记录中的数据。使用这些方法是根据返回值的需要来确定。使用isNull()方法可以判断输出参数是否为空。本例中使用了getString()来获取学生的姓名、年龄、住址、电话信息,使用了getInt()方法来获取学生的班级号码。

程序实现步骤如下:

1.编写useParameterResultSet 类的基本框架,在该类中仅包括main()方法,在main()方法中先加载驱动程序,建立与数据库的连接,对数据库执行一般查询,接着执行参数查询,最后执行存储过程。

2.该类的全部代码如下:

//使用了JDBC 类、DriverManager 类和系统输出,所以需要引入如下的包:
import java.sql.*;
import java.io.*;
//import java.util.*;
class useParameterResultSet
{
public static void main(String argv[])
{
String url="jdbc.odbc:useDSN";
String name,age,address,telephone;
int cno;
java.sql.ResultSet rs;
try
{
//加载驱动程序
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
//建立连接
Connection con=DriverManager.getConnection(url,"sa","");
//创建文件输入流
File file=new File("d:/java/usefile.txt");
int flength=2;
InputStream fis=new FileInputStream(file);
//创建PreparedStatement 对象
String sqlstr="select * from student where age=?";
PreparedStatement ps=con.prepareStatement(sqlstr);
//设置输入参数
ps.setAsciiStream(1,fis,flength);
//获得结果集
rs=ps.executeQuery();
//输出结果集
System.out.println("查询结果:");
while(rs.next())
{
name=rs.getString("name");
age=rs.getString("age");
cno=rs.getInt("classno");
address=rs.getString("address");
telephone=rs.getString("telephone");
System.out.println(name+" "+age+" "+cno+" "+address+" "+telephone);
}
con.close();
}
catch(Exception e)
{
System.out.println(e.getMessage());
e.printStackTrace();
}
}
}

感兴趣的读者可以动手测试一下本文所述实例,相信会给大家的Java项目开发起到一定的帮助作用。

 类似资料:
  • 本文向大家介绍thinkPHP5实现数据库添加内容的方法,包括了thinkPHP5实现数据库添加内容的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了thinkPHP5实现数据库添加内容的方法。分享给大家供大家参考,具体如下: 面对一个新框架安装好了一般不知道要干啥。那就先做一个写入功能先。 先做好准备工作先,首先要连接上数据库。 配置文件在application下的database.

  • 我试图显示一个零件的"loc",如果它的零件号我给。以下是数据结构的样子: 活动代码: getLoc是Product类的getter函数,它返回给定curP对应的“loc”。curP部分表示子值。 逻辑对我来说似乎是正确的,但我没有得到输出。我哪里出了问题?

  • 请帮助我想从Firebase实时数据库检索一个特定的数据,我有2个用户,教授和学生,我想使用该数据进行验证。 FireBase实时数据库 FireBase实时数据库

  • 问题内容: 我对选择两种方法感到困惑。 方案 有两个表,并分别。包含用户数据,例如名字,姓氏等 包含每个用户拥有的汽车及其说明。即,等等 现在,如果我想获得所有用户的所有信息,那么哪种方法最好在最短的时间内完成? 方法1。 查询其中的所有行,并将它们全部存储在ex的列表中。 然后循环浏览列表并对其进行查询,并根据第一步中保存的用户从中获取数据。 方法2 查询所有行,并在保存该行时从中获取所有值并保

  • 本文向大家介绍php实现redis数据库指定库号迁移的方法,包括了php实现redis数据库指定库号迁移的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php实现redis数据库指定库号迁移的方法,分享给大家供大家参考。具体如下: redis普通的数据库迁移,只能整个redis save,或者利用主从,当然也可以安装一个redis-dump,不过比较麻烦,这里提供一种php的脚本,实