05 jdbc 处理大容量数据

大数量数据:

  1. 字符:
    存储字符内容: mysql: char varchar 长度有限的。 65535
    大容量的字符字段:
    mysql: text longtext(4G字符内容)
    oracle : clob longclob

  2. 字节:
    mysql: blob(65kb) mediumblob(16mb) longblog(4GB)
    oracle: blob

使用jdbc操作text字段:

Paste_Image.png
public class Demo1 {

    public static void main(String[] args) {
        //write();
        
        /**
         * 读取
         */
        Connection conn = null;
        PreparedStatement stmt = null;
        ResultSet rs = null;
        try{
            conn = JdbcUtil.getConnection();
            String sql = "select * from news where id=?";
            stmt = conn.prepareStatement(sql);
            stmt.setInt(1, 1);
            //执行查询
            rs = stmt.executeQuery();
            
            //读取结果集
            while(rs.next()){
                
                //获取text字段
                //1)可以把text字段内容当前字符串读取
            /*  String content = rs.getString("content");
                System.out.println(content);
                */
                
                //2)可以把text字段当做输入流读取
                Clob clob = rs.getClob("content");
                //通过clob字段读取输入流
                Reader reader = clob.getCharacterStream();
                
                //把输入流输出到文件中
                FileWriter writer = new FileWriter("e:/abc.txt");
                char[] buf = new char[512];
                int len = 0;
                while(  (len=reader.read(buf))!=-1 ){
                    //边读边写出
                    writer.write(buf, 0, len);
                }
                //关闭流
                writer.close();
                reader.close();
            }
        }catch(Exception e){
            e.printStackTrace();
        }finally{
            JdbcUtil.close(stmt, conn);
        }
    }

    private static void write() {
        /**
         * 写入
         */
        Connection conn = null;
        PreparedStatement stmt = null;
        try{
            conn = JdbcUtil.getConnection();
            String sql = "insert into news(title,content) values(?,?)";
            //预编译
            stmt = conn.prepareStatement(sql);
            //参数赋值
            stmt.setString(1, "昨天是父亲节,全国各地都在纷纷庆祝!!!");
            /**
             * 读取本地的字符文件
             */
            Reader reader = new FileReader("e:/url.txt");
            //设置text字段
            stmt.setClob(2, reader);
            
            //执行
            stmt.executeUpdate();
            System.out.println("添加成功");
        }catch(Exception e){
            e.printStackTrace();
        }finally{
            JdbcUtil.close(stmt, conn);
        }
    }
}

使用jdbc操作blob字段:

Paste_Image.png
public class Demo2 {

    public static void main(String[] args) {
        //write();
        
        /**
         * 读取
         */
        Connection conn = null;
        PreparedStatement stmt = null;
        ResultSet rs = null;
        try{
            conn = JdbcUtil.getConnection();
            String sql = "select * from news where id=?";
            stmt = conn.prepareStatement(sql);
            stmt.setInt(1, 1);
            rs = stmt.executeQuery();
            
            while(rs.next()){
            
                //读取blob字段
                Blob blob = rs.getBlob("attachments");
                //通过blob字段获取输入字节流
                InputStream in = blob.getBinaryStream();
                
                //把输入字节流写出文件中
                FileOutputStream out = new FileOutputStream("e:/abc.mp3");
                byte[] buf = new byte[1024];
                int len = 0;
                //边读边写
                while( (len=in.read(buf))!=-1  ){
                    out.write(buf, 0, len);
                }  
                //关闭流
                out.close();
                in.close();
            }
            
        }catch(Exception e){
            e.printStackTrace();
        }finally{
            JdbcUtil.close(stmt, conn);
        }
    }

    private static void write() {
        /**
         * 写入
         */
        Connection conn = null;
        PreparedStatement stmt = null;
        try{
            conn = JdbcUtil.getConnection();
            String sql = "update news set attachments=? where id=?";
            //预编译
            stmt = conn.prepareStatement(sql);
            //参数赋值
            /**
             * 读取本地字节文件
             * 注意:
             *  1)发送的数据内容超过了字段的长度限制,则抛出 Data too long...异常,这时需要修改字段的类型
             *  2)发送的数据内容超过了1MB(mysql服务器默认的接收数据包的大小),可以到mysql安装目录下的my.ini文件添加一个变量max_allowed_packet=50M即可!
             */
            InputStream in = new FileInputStream("e:/02.mp3");
            /**
             * 设置blob字段
             */
            stmt.setBlob(1, in);
            stmt.setInt(2, 1);
            //执行
            stmt.executeUpdate();
            System.out.println("添加成功");
        }catch(Exception e){
            e.printStackTrace();
        }finally{
            JdbcUtil.close(stmt, conn);
        }
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 什么是数据库? 数据库是存储数据的集合的单独的应用程序。每个数据库具有一个或多个不同的API,用于创建,访问,管理...
    chen_000阅读 4,035评论 0 19
  • 本文基于MySQL5.6版本进行描述从大的方面来讲,MySQL的数据类型分为4种 数值类型 日期和时间 字符串类型...
    黑哥儿666阅读 746评论 0 0
  • A.字段类型介绍 不同的关系型数据库在字段类型的具体化上差异较多,这里无法一一详述,但具体化的字段类型再多,无外乎...
    SnowflakeCloud阅读 11,166评论 1 12
  • 排除所有不可能的,剩下的那个即使再不可思议,那也是事实——夏洛克·福尔摩斯 1、惧怕改变 朋友A从一离开学校就在某...
    洪生鹏阅读 2,310评论 1 8
  • “就差一个程序员了”,“就差搞技术的了”,这样的话在中关村我们听到的已经太多了。 事实上,做技术的到哪都不愁没饭吃...
    创业者们阅读 489评论 2 1