首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在peewee中设置严格的sql模式

在peewee中设置严格的sql模式
EN

Stack Overflow用户
提问于 2015-03-03 18:48:27
回答 1查看 591关注 0票数 0

我想在我的mySQL数据库中强制使用ENUM约束。为此,建议我使用“严格”sql模式。在交互式提示符中,可以将其设置为:

代码语言:javascript
复制
SET GLOBAL sql_mode = 'STRICT_ALL_TABLES';
SET SESSION sql_mode = 'STRICT_ALL_TABLES';

或在服务器启动时:

代码语言:javascript
复制
 --sql-mode="STRICT_ALL_TABLES"

或在my.cnf中为:

代码语言:javascript
复制
sql-mode="STRICT_ALL_TABLES"

peewee中有做这种事情的方法吗?也许是通过扩展Database类?还是在查询中注入原始sql?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-03 21:51:12

您最好的选择是可能将MySQLDatabase子类化并重写_connect()方法。

代码语言:javascript
复制
class StrictMySQLDatabase(MySQLDatabase):
    def _connect(self, database, **kwargs):
        conn = super(StrictMySQLDatabase, self)._connect(database, **kwargs)
        cursor = conn.cursor()
        cursor.execute("SET SESSION sql_mode = 'STRICT_ALL_TABLES';")
        return conn
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28839615

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档