美文网首页postgresql
pgsql数据类型:二进制字符类型

pgsql数据类型:二进制字符类型

作者: 老柿子 | 来源:发表于2020-08-19 21:17 被阅读0次

    二进制字符串

    名字 存储尺寸 描述
    bytea 1或4字节外加真正的二进制串 变长二进制串
    db=# create table demo_bytea(bytea bytea);
    

    插入

    插入文本

    db=# insert into demo_bytea values('123');
    INSERT 0 1
    db=# select * from demo_bytea;
      bytea
    ----------
     \x313233
    (1 row)
    

    插入转义类型

    这个不是很理解,什么叫转义类型,我的理解,就是将二进制的表示为八进制或者十六进制这种字符串,为什么这么表示,主要是有一些特殊的字符比如\b\n\t,这种需要转义的字符,如果不转义,则作为字符串添加进去的话,就会有问题,所以才需要通过八进制或者十六进制的方式进行表示(因为直接用二进制太长了,虽然也是可以)。插入的时候怎么使用呢

    插入八进制数据
    db=# insert into demo_bytea values('\001');
    INSERT 0 1
    db=# insert into demo_bytea values('\002');
    INSERT 0 1
    db=# insert into demo_bytea values('\003');
    INSERT 0 1
    db=# select * from demo_bytea;
     bytea
    -------
     \x01
     \x02
     \x03
    (3 rows)
    
    db=# insert into demo_bytea values('\001');
    INSERT 0 1
    db=# insert into demo_bytea values('\001\002');
    INSERT 0 1
    db=# insert into demo_bytea values('\001\002\032');
    INSERT 0 1
    db=# insert into demo_bytea values('\001\002\032\101');
    INSERT 0 1
    db=# insert into demo_bytea values('\001\002\032\101\021');
    INSERT 0 1
    db=# select * from demo_bytea;
        bytea
    --------------
     \x01
     \x0102
     \x01021a
     \x01021a41
     \x01021a4111
    (5 rows)
    
    插入十六进制数据
    db=# insert into demo_bytea values(E'\x01');
    INSERT 0 1
    db=# insert into demo_bytea values(E'\x02');
    INSERT 0 1
    db=# insert into demo_bytea values(E'\x03');
    INSERT 0 1
    db=# insert into demo_bytea values(E'\x04');
    INSERT 0 1
    db=# insert into demo_bytea values(E'\x05');
    INSERT 0 1
    db=# select * from demo_bytea;
     bytea
    -------
     \x01
     \x02
     \x03
     \x04
     \x05
    

    base64编码

    通过base64编码将数据插入进去

    db=# select encode('你好', 'base64');
      encode
    ----------
     5L2g5aW9
    (1 row)
    
    db=# insert into demo_bytea values(decode('5L2g5aW9', 'base64'));
    INSERT 0 1
    db=# select * from demo_bytea;
         bytea
    ----------------
     \xe4bda0e5a5bd
    (1 row)
    

    本地路径

    将本地的文件插入到pg数据库中,通过函数

    函数 返回类型 描述
    pg_read_file(filename text [, offset bigint, length bigint]) text 返回文件内容为text格式
    pg_read_binary_file(filename text [, offset bigint, length bigint]) bytea 返回文件内容为bytea格式
    文本方式读入

    注意如果采用文本,则需要强制转换,否则会失败

    db=# insert into demo_bytea values(pg_read_file('/var/file/test.txt')::bytea);
    INSERT 0 1
    db=# select * from demo_bytea;
     bytea
    --------
     \x320a
    (1 row)
    

    不转换的话会失败

    db=# insert into demo_bytea values(pg_read_file('/var/file/test.txt'))
    db-# ;
    ERROR:  column "bytea" is of type bytea but expression is of type text
    LINE 1: insert into demo_bytea values(pg_read_file('/var/file/test.t...
                                          ^
    HINT:  You will need to rewrite or cast the expression.
    
    二进制文本读入
    db=# create table demo_time(time time);
    CREATE TABLE
    db=# insert into demo_bytea values(pg_read_binary_file('/var/file/test.txt'));
    INSERT 0 1
    db=# select * from demo_bytea;
     bytea
    --------
     \x320a
    (1 row)
    

    其中文件的内容为

    # cat test.txt
    2
    

    读取

    后端代码中进行读取,这里用到自己的Orm框架Neo()

    @Test
    public void test3(){
        String url="jdbc:postgresql://localhost:54321/db";
        String user = "postgres";
        String password = "pg.123";
        Neo db = Neo.connect(url, user, password);
    
    
        ByteaDO result = db.one(ByteaDO.class, "demo_bytea", NeoMap.of());
        // 320a
        show(HexUtils.toHexString(result.getBytea()));
        // 2
        show(new String(result.getBytea()));
    }
    

    参考:

    官网
    http://postgres.cn/docs/11/datatype-binary.html
    其他
    https://blog.csdn.net/xinpo66/article/details/18961427

    相关文章

      网友评论

        本文标题:pgsql数据类型:二进制字符类型

        本文链接:https://www.haomeiwen.com/subject/reodjktx.html