栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在自定义的编译表达式中使用bindparam()?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在自定义的编译表达式中使用bindparam()?

我知道了。bindparams的实际值保存在一个称为的对象中,该对象

SQLCompiler
通常是特定于方言的。
这里(链接到GitHub)是在
SQLCompiler
查询编译过程中将bindparams存储在实例中的位置

因此,我的代码段的最终版本如下所示:

class values(FromClause):    named_with_column = True    def __init__(self, columns, *args, **kw):        self._column_args = columns        self.list = args        self.alias_name = self.name = kw.pop('alias_name', None)    def _populate_column_collection(self):        # self._columns.update((col.name, col) for col in self._column_args)        for c in self._column_args: c._make_proxy(self, c.name)@compiles(values)def compile_values(clause, compiler, asfrom=False, **kw):    def decide(value, column):        add_type_hint = False        if isinstance(value, array) and not value.clauses:  # for empty array literals add_type_hint = True        if isinstance(value, ClauseElement): intermediate = compiler.process(value) if add_type_hint:     intermediate += '::' + str(column.type) return intermediate        elif value is None: return compiler.render_literal_value(     value,     NULLTYPE ) + '::' + str(column.type)        else: return compiler.process(     bindparam(         None,         value=compiler.render_literal_value(  value,  column.type         ).strip("'")     ) ) + '::' + str(column.type)    columns = clause.columns    v = "VALUES %s" % ", ".join(        "(%s)" % ", ".join( decide(elem, column) for elem, column in zip(tup, columns))        for tup in clause.list    )    if asfrom:        if clause.alias_name: v = "(%s) AS %s (%s)" % (v, clause.alias_name, (", ".join(c.name for c in clause.columns)))        else: v = "(%s)" % v    return v


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/596664.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号