如何指示 SQLAlchemy 在 create_all() 上创建 SQLite FTS3 表?

发布于 2024-09-27 08:19:33 字数 146 浏览 0 评论 0原文

我希望 SQLAlchemy 在 .create_all() 期间创建一个 FTS3 表。我需要添加哪些特殊选项才能让它知道CREATE VIRTUAL TABLE ... USING FTS3(tokenizer=...)

I would like SQLAlchemy to create an FTS3 table during .create_all(). What special options do I need to add so it knows to CREATE VIRTUAL TABLE ... USING FTS3(tokenizer=...)?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

迷乱花海 2024-10-04 08:19:33

据我所知,要实现这个未来,您必须改进 sqlite 方言来更改 create_table 行为。

但是你可以使用这个快速但丑陋的解决方案“monkeypatching”

# ugly monkeypatch
from sqlalchemy.dialects.sqlite.base import SQLiteDDLCompiler

old_create_table = SQLiteDDLCompiler.visit_create_table

def new_create_table(*args, **kwargs):
    sql = old_create_table(*args, **kwargs)
    # TODO 
    # 1) check table with FTS3 
    # 2) change sql to CREATE VIRTUAL TABLE ... USING FTS3(tokenizer=...)
    print 'SQL: %s' % sql
    return sql

SQLiteDDLCompiler.visit_create_table = new_create_table
# end of ugly monkey patch

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import schema, MetaData, Column, Integer

metadata = MetaData()
Base = declarative_base(metadata=metadata) 

class MyModel(Base):
    __tablename__ = 'table'
    id = Column(Integer, primary_key=True)

if __name__ == '__main__':
    from sqlalchemy import create_engine
    engine = create_engine('sqlite:///', echo=True)
    metadata.bind = engine
    metadata.create_all() 

As I know to implement this futer you must improve sqlite dialect to change create_table behavior.

But you can use this quick, but ugly solution with "monkeypatching"

# ugly monkeypatch
from sqlalchemy.dialects.sqlite.base import SQLiteDDLCompiler

old_create_table = SQLiteDDLCompiler.visit_create_table

def new_create_table(*args, **kwargs):
    sql = old_create_table(*args, **kwargs)
    # TODO 
    # 1) check table with FTS3 
    # 2) change sql to CREATE VIRTUAL TABLE ... USING FTS3(tokenizer=...)
    print 'SQL: %s' % sql
    return sql

SQLiteDDLCompiler.visit_create_table = new_create_table
# end of ugly monkey patch

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import schema, MetaData, Column, Integer

metadata = MetaData()
Base = declarative_base(metadata=metadata) 

class MyModel(Base):
    __tablename__ = 'table'
    id = Column(Integer, primary_key=True)

if __name__ == '__main__':
    from sqlalchemy import create_engine
    engine = create_engine('sqlite:///', echo=True)
    metadata.bind = engine
    metadata.create_all() 
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文