হ্যাঁ, আপনি নতুন কলাম যুক্ত না করেই পারেন। ডাটাবেসটি ক্ষতিগ্রস্ত না করতে যাতে সঠিকভাবে তা করতে আপনাকে সতর্ক হতে হবে, তাই চেষ্টা করার আগে আপনার ডাটাবেসটিকে পুরোপুরি ব্যাকআপ করা উচিত।
আপনার নির্দিষ্ট উদাহরণের জন্য:
CREATE TABLE child(
id INTEGER PRIMARY KEY,
parent_id INTEGER,
description TEXT
);
--- create the table we want to reference
create table parent(id integer not null primary key);
--- now we add the foreign key
pragma writable_schema=1;
update SQLITE_MASTER set sql = replace(sql, 'description TEXT)',
'description TEXT, foreign key (parent_id) references parent(id))'
) where name = 'child' and type = 'table';
--- test the foreign key
pragma foreign_keys=on;
insert into parent values(1);
insert into child values(1, 1, 'hi'); --- works
insert into child values(2, 2, 'bye'); --- fails, foreign key violation
বা আরও সাধারণভাবে:
pragma writable_schema=1;
// replace the entire table's SQL definition, where new_sql_definition contains the foreign key clause you want to add
UPDATE SQLITE_MASTER SET SQL = new_sql_definition where name = 'child' and type = 'table';
// alternatively, you might find it easier to use replace, if you can match the exact end of the sql definition
// for example, if the last column was my_last_column integer not null:
UPDATE SQLITE_MASTER SET SQL = replace(sql, 'my_last_column integer not null', 'my_last_column integer not null, foreign key (col1, col2) references other_table(col1, col2)') where name = 'child' and type = 'table';
pragma writable_schema=0;
যে কোনও উপায়ে, আপনি সম্ভবত কোনও পরিবর্তন করার আগে প্রথমে এসকিউএল সংজ্ঞা কী তা দেখতে চাইবেন:
select sql from SQLITE_MASTER where name = 'child' and type = 'table';
আপনি যদি প্রতিস্থাপন () পদ্ধতির ব্যবহার করেন তবে কার্যকর করার আগে, প্রথমে আপনার প্রতিস্থাপন () কমান্ডটি চালিয়ে যাচাই করার জন্য আপনি এটি সহায়ক হতে পারেন:
select replace(sql, ...) from SQLITE_MASTER where name = 'child' and type = 'table';