怎么获取SQL2000 ntext字段数据 10
SQL表里面字段user是varchar类型的用Rs.getString("user");可以获取但是如果字段user是ntext类型该怎么获取呢?用Rs.getStri...
SQL 表里面字段user是varchar类型的用Rs.getString("user");可以获取
但是如果字段user是ntext类型该怎么获取呢?用Rs.getString("user");这样获取不到
急急急急急急急急急急急急急急急急急急 在 线 等 展开
但是如果字段user是ntext类型该怎么获取呢?用Rs.getString("user");这样获取不到
急急急急急急急急急急急急急急急急急急 在 线 等 展开
展开全部
读取ntext型大文本数据,用getBinaryStream()方法。 继续看希望能帮到您!
在数据库(ms-sql)中使用ntext等大文本类型的数据时,当文本长度很大时,(比如超过4000),在使用select语句获得的数据集中将无法直接得到该字段的内容,必须要用其他方法获得。cx
在java中可用ResultSet对象存放数据集,但无法直接将结果集中的ntext内容转换为字符串(如使用ResultSet对象的各getString()方法),而要用到ResultSet对象的getBinaryStream()方法。rpZT
下面是一段完整地java代码,将整个过程放在一个类中,代码中有较详细地说明,这里不再赘述,敬请各位参考、指正:(如有更好的办法请及时说明)j
(在代码中每次从数据库读取一个字节,是应为不知道数据库存放页面文件的最小占用空间是否为簇,否则可以一次多读一些了!)
//代码起始2
import java.io.InputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.ResultSet;
import java.sql.DriverManager;
import java.sql.Connection;
import java.lang.ClassNotFoundException;
public class ReadBlobFromDatabase {=,KAv
public ReadBlobFromDatabase() {
try {
//加载数据库驱动程序,这里使用jdbc-odbc数据桥建立与数据库的连接s
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
Connection conn = DriverManager.getConnection("jdbc:odbc:srrmis", "username", "passwd");
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_UPDATABLE)
//执行查询,获得结果集。在这个SQL语句中,ntext_column是一个ntext类型的字段,}49
//约束条件选择index值为2的记录H94yV
ResultSet rs = stmt.executeQuery(
"select ntext_column from mytable where [index]= 2 ")
//将记录集中的指针指向第一条记录F
if (rs.next()) {
//定义整数c,存放InputStream读出来的字节所对应的整数e
int c;
InputStream is = rs.getBinaryStream(1);
//将二进制数据字节流转换为字符流,编码为16位、低位顺序的双字节国家字符(微机格式)j)
InputStreamReader isr = new InputStreamReader(is, "UnicodeLittle");
//循环读取文本对应的字节,直到文本结尾nd
while ( (c = isr.read()) != -1) {;
String tmpString = "" + (char) ;
//这里用输出测试读出的结果,如果想将各个字符组合、或执行其他的处理,JX
//可以在这里编写代码{9
System.out.print(tmpString);
}
}
}
在数据库(ms-sql)中使用ntext等大文本类型的数据时,当文本长度很大时,(比如超过4000),在使用select语句获得的数据集中将无法直接得到该字段的内容,必须要用其他方法获得。cx
在java中可用ResultSet对象存放数据集,但无法直接将结果集中的ntext内容转换为字符串(如使用ResultSet对象的各getString()方法),而要用到ResultSet对象的getBinaryStream()方法。rpZT
下面是一段完整地java代码,将整个过程放在一个类中,代码中有较详细地说明,这里不再赘述,敬请各位参考、指正:(如有更好的办法请及时说明)j
(在代码中每次从数据库读取一个字节,是应为不知道数据库存放页面文件的最小占用空间是否为簇,否则可以一次多读一些了!)
//代码起始2
import java.io.InputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.ResultSet;
import java.sql.DriverManager;
import java.sql.Connection;
import java.lang.ClassNotFoundException;
public class ReadBlobFromDatabase {=,KAv
public ReadBlobFromDatabase() {
try {
//加载数据库驱动程序,这里使用jdbc-odbc数据桥建立与数据库的连接s
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
Connection conn = DriverManager.getConnection("jdbc:odbc:srrmis", "username", "passwd");
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_UPDATABLE)
//执行查询,获得结果集。在这个SQL语句中,ntext_column是一个ntext类型的字段,}49
//约束条件选择index值为2的记录H94yV
ResultSet rs = stmt.executeQuery(
"select ntext_column from mytable where [index]= 2 ")
//将记录集中的指针指向第一条记录F
if (rs.next()) {
//定义整数c,存放InputStream读出来的字节所对应的整数e
int c;
InputStream is = rs.getBinaryStream(1);
//将二进制数据字节流转换为字符流,编码为16位、低位顺序的双字节国家字符(微机格式)j)
InputStreamReader isr = new InputStreamReader(is, "UnicodeLittle");
//循环读取文本对应的字节,直到文本结尾nd
while ( (c = isr.read()) != -1) {;
String tmpString = "" + (char) ;
//这里用输出测试读出的结果,如果想将各个字符组合、或执行其他的处理,JX
//可以在这里编写代码{9
System.out.print(tmpString);
}
}
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询