ClickHouse写入数据报错Code: 27, e.displayText() = DB::ParsingException: Cannot parse input: expected ‘\t‘

刚开始接触到这个错误,以为是插入数据的格式问题,字段间的分隔符出现问题,于是我在插入语句中加了“format TabSparatedRaw”,之后错误确实发生改变,变为“插入的首个字段数据前多了一个\n”。在此处我琢磨了一上午。后来参考插入clickhouse其他表的代码,甚至打印出praparedStatement填充数据后的sql语句,但是依旧无效。两者的插入语句完全相同,但是第二个就是插入不进去。后来比对clickhouse中的数据类型,终于发现错误。是建立ClickHouse表的时候数据类型没有选对。
ClickHouse 支持的数据类型
整型
有符号整型:Int8, Int16, Int32, Int64
无符号整型:UInt8, UInt16, UInt32, UInt64

下面的无符号整型是不支持“-1”等负数数据插入的。
参考:官网描述

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个误可能是因为您正在使用的FTP服务器并不是标准的FTP协议,而是使用了SSH协议。要连接到使用SSH协议的FTP服务器,您需要使用SFTP而不是FTP协议。可以尝试使用JSch库来连接SFTP服务器。 以下是使用JSch连接SFTP服务器的示例代码: ```java import com.jcraft.jsch.*; public class SFTPExample { public static void main(String[] args) { String host = "sftp.example.com"; String username = "username"; String password = "password"; int port = 22; Session session = null; Channel channel = null; ChannelSftp sftpChannel = null; try { JSch jsch = new JSch(); session = jsch.getSession(username, host, port); session.setPassword(password); session.setConfig("StrictHostKeyChecking", "no"); session.connect(); channel = session.openChannel("sftp"); channel.connect(); sftpChannel = (ChannelSftp) channel; // 在这里可以执行SFTP操作,例如上传/下载/删除文件等 // 例如,上传本地文件到远程服务器: sftpChannel.put("localFile.txt", "remoteFile.txt"); } catch (JSchException | SftpException e) { e.printStackTrace(); } finally { if (sftpChannel != null) { sftpChannel.exit(); } if (channel != null) { channel.disconnect(); } if (session != null) { session.disconnect(); } } } } ``` 您需要将`host`、`username`、`password`和`port`替换为您要连接的SFTP服务器的实际值。在示例代码中,我们使用`JSch`库创建一个SFTP会话并进行连接。然后,我们打开一个SFTP通道,并执行一些SFTP操作,例如将本地文件上传到远程服务器。最后,我们关闭SFTP通道和会话。 希望这可以解决您的问题!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值