处理大对象数据-处理CLOB数据

大对象处理主要值CLOB和BLOB两种类型的字段,在CLOB中可以存储海量文字,在BLOB中可以存储二进制数据,如果在程序中药理大对象数据,则必须使用PreparedStatement完成,所有的内容要通过IO流的方式从大文本字段中保存和读取。
1 使用IO流保存操作

import java.sql.* ;
import java.io.File ;
import java.io.FileInputStream ;
import java.io.InputStream ;
public class ClobDemo01
{   
    //定义数据库驱动程序
    public static final String driver = "org.gjt.mm.mysql.Driver" ;
    //定义数据库连接地址
    public static final String url = "jdbc:mysql://localhost:3306/spiderman" ;
    //定义数据库名称
    public static final String user = "root" ;
    //定义数据库密码
    public static final String pass = "" ;

    public static void main(String[] args)
    {   //加载数据库驱动程序
        try
        {
            Class.forName(driver) ;
        }
        catch(ClassNotFoundException e)//抛出异常
        {
            e.printStackTrace() ;
            return ;
        }

        //加载数据库连接
        Connection conn = null ;
        try
        {
            conn = DriverManager.getConnection(url,user,pass);

        }
        catch(SQLException e)
        {
            e.printStackTrace() ;
            return ;
        }

        //执行数据库操作
        PreparedStatement pst = null ;
        String name = "IronMan" ;   //表示姓名
        String sql =  "Insert Into useclob(user,note)values(?,?) "; 

        File f = new File("f:"+File.separator+"prince.txt") ;
        InputStream input = null ;
        try
        {
            pst = conn.prepareStatement(sql);//实例化Statement对象

            try
            {
                input = new FileInputStream(f) ;  //通过输出流读取文件
            }
            catch(Exception e)
            {
                e.printStackTrace() ;   
            }

            pst.setString(1,name) ;
            pst.setAsciiStream(2,input) ; 
            pst.executeUpdate();

        }
        catch(SQLException e)
        {
            e.printStackTrace();
            return ;
        }


        finally
        {   
            if(pst!=null)
            {
                try
                {
                    pst.close();
                }
                catch(SQLException e)
                {
                    e.printStackTrace();
                }
            }

            if(conn!=null)
            {
                try
                {
                    conn.close();
                }
                catch(SQLException e)
                {
                    e.printStackTrace();
                }
            }
        }       
    }
}

你可能感兴趣的:(Java)