在wsl的python 3.14.3容器中使用databend包

pypi上的databend项目页面:https://pypi.org/project/databend/

在旧版的linux上安装会报错,虽然可以解决,但是在python中import报错就没办法了。

复制代码
import databend

thread '<unnamed>' panicked at /root/.cargo/registry/src/index.crates.io-1949cf8c6b5b557f/tokio-1.45.0/src/runtime/scheduler/multi_thread/worker.rs:460:13:
OS can't spawn worker thread: Operation not permitted (os error 1)
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
fatal runtime error: failed to initiate panic, error 2761651232
Aborted (core dumped)

再在WSL中安装,应该是Linux版本够高,所以安装,导入都成功。

按照页面介绍的语法,显示版本号。

复制代码
pip install databend
python3
Python 3.14.3 (main, Feb  4 2026, 20:08:31) [GCC 14.2.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import databend; ctx = databend.SessionContext(); ctx.sql('SELECT version() AS version')
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
│                                              version                                             │
│                                              String                                              │
├──────────────────────────────────────────────────────────────────────────────────────────────────┤
│ 'Databend Query v1.2.810-nightly-613a23a366(rust-1.88.0-nightly-2025-09-10T16:50:37.672119017Z)' │
└──────────────────────────────────────────────────────────────────────────────────────────────────┘

但是查询本地文件注册就报错了。

复制代码
>>> ctx.register_tsv("cxy", "/par/data/cxy.tsv", pattern=None, connection=None)
Traceback (most recent call last):
  File "<python-input-9>", line 1, in <module>
    ctx.register_tsv("cxy", "/par/data/cxy.tsv", pattern=None, connection=None)
    ~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
RuntimeError: DataFrame collect error: SemanticError. Code: 1065, Text = [QUERY-CTX] Query from TSV file lacks column positions. Specify as $1, $2, etc..

<Backtrace disabled by default. Please use RUST_BACKTRACE=1 to enable>

经求教Databend支持人员,告诉我应该用如下语法,并且不能用*,必须用占位符明确指定列:

复制代码
>>> ctx.sql("select * from 'fs:///' (files=>('/par/data/cxy.tsv'),file_format=>'tsv')")
Traceback (most recent call last):
  File "<python-input-4>", line 1, in <module>
    ctx.sql("select * from 'fs:///' (files=>('/par/data/cxy.tsv'),file_format=>'tsv')")
    ~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
RuntimeError: Error: SemanticError. Code: 1065, Text = [QUERY-CTX] Query from TSV file lacks column positions. Specify as $1, $2, etc..
>>> ctx.sql("select $1,$2,$3 from 'fs:///' (files=>('/par/data/cxy.tsv'),file_format=>'tsv')")
┌────────────────────────────────────────────┐
│      $1     │      $2     │       $3       │
│ String NULL │ String NULL │   String NULL  │
├─────────────┼─────────────┼────────────────┤
│ 'id'        │ 'name'      │ 'language\r'   │
│ '1'         │ 'Joe'       │ 'Java\r'       │
│ '2'         │ 'Alice'     │ 'JavaScript\r' │
│ '3'         │ 'Leon'      │ 'C/C++\r'      │
│ '4'         │ 'William'   │ 'Java\r'       │
│ '5'         │ 'James'     │ 'C/C++\r'      │
│ '6'         │ 'Enson'     │ 'C/C++'        │
└────────────────────────────────────────────┘

其实还是有个问题,标题行被作为数据显示出来了。而parquet文件正好相反,如果用*直接显示内容。用1占位符反而显示json格式,工作人员解释在 parquet 上执行: select 1 ,是指把所有的列整体当做一个 variant 类型,遵循 snowflake 的语法方式。

复制代码
>>> ctx.sql("select $1 from 'fs:///' (files=>('/par/duck.parquet'),file_format=>'parquet')")
┌──────────────────────────┐
│            $1            │
│          Variant         │
├──────────────────────────┤
│ '{"mpz_sum":"13522500"}' │
└──────────────────────────┘
>>> ctx.sql("select * from 'fs:///' (files=>('/par/duck.parquet'),file_format=>'parquet')")
┌─────────────┐
│   mpz_sum   │
│ String NULL │
├─────────────┤
│ '13522500'  │
└─────────────┘
相关推荐
小高不会迪斯科5 小时前
CMU 15445学习心得(二) 内存管理及数据移动--数据库系统如何玩转内存
数据库·oracle
寻寻觅觅☆5 小时前
东华OJ-基础题-106-大整数相加(C++)
开发语言·c++·算法
YJlio5 小时前
1.7 通过 Sysinternals Live 在线运行工具:不下载也能用的“云端工具箱”
c语言·网络·python·数码相机·ios·django·iphone
e***8905 小时前
MySQL 8.0版本JDBC驱动Jar包
数据库·mysql·jar
赶路人儿6 小时前
Jsoniter(java版本)使用介绍
java·开发语言
ceclar1236 小时前
C++使用format
开发语言·c++·算法
山塘小鱼儿6 小时前
本地Ollama+Agent+LangGraph+LangSmith运行
python·langchain·ollama·langgraph·langsimth
码说AI7 小时前
python快速绘制走势图对比曲线
开发语言·python