首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLite语法化foreign_keys问题

SQLite语法化foreign_keys问题
EN

Stack Overflow用户
提问于 2009-12-01 09:48:46
回答 2查看 2.8K关注 0票数 0

我已经修改了System.Data.SQLite以使用最新版本的SQLite引擎,该引擎无需使用自定义触发器即可自动实施外键。

我也在使用SubSonic 2.x,但这将适用于任何使用SQLite的ORM框架,这些框架是“开放晚,关闭早”的。

如何确保在每个SQLiteConnection.Open()上都会调用'PRAGMA foreign_keys=true‘语句?它必须被调用,否则外键将不起作用。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-12-02 04:37:34

为了解决这个问题,我在SQLiteConnection类的ConnectionString中添加了一个“外键”属性。

外部Keys=ON外部Keys=OFF

票数 2
EN

Stack Overflow用户

发布于 2009-12-17 00:07:05

如果您想使用最新版本的SQLite,则不需要修改System.Data.SQLite,只需使用ManagedOnly版本的System.Data.SQLite,然后只用最新版本替换sqlite3.dll即可。为了启用外键支持,我只需执行一条启用外键支持的sql语句。例如:

代码语言:javascript
复制
        string databasePath = "Your database path here";
        string connectionString = "Data Source=" + databasePath;
        connection = new SQLiteConnection(connectionString);
        connection.Open();

        const string sqlString = "PRAGMA foreign_keys = ON;";
        SQLiteCommand command = new SQLiteCommand(sqlString, connection);
        command.ExecuteNonQuery();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1823537

复制
相关文章

相似问题

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