Используя sqlite3 стандартную библиотеку Python 2.6.4, следующий запрос отлично работает на sqlite3 командной строки:питон sqlite3 не выполнится присоединиться, но sqlite3 только будет
select segmentid, node_t, start, number,title from
((segments inner join position using (segmentid))
left outer join titles using (legid, segmentid))
left outer join numbers using (start, legid, version);
Но если я исполню ее с помощью sqlite3 библиотека питона я получаю ошибку:
>>> conn=sqlite3.connect('data/test.db')
>>> conn.execute('''select segmentid, node_t, start, number,title from
((segments inner join position using (segmentid)) left outer join titles using
(legid, segmentid)) left outer join numbers using (start, legid, version)''')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
sqlite3.OperationalError: cannot join using column start - column not present
in both tables
The (вычисленные) таблицы на левой стороне появляется присоединиться, чтобы иметь соответствующую колонку, потому что, если я проверить это сам по себе я получаю:
>>> conn.execute('''select * from ((segments inner join position using
(segmentid)) left outer join titles using
(legid, segmentid)) limit 20''').description
(('segmentid', None, None, None, None, None, None), ('html', None, None, None,
None, None, None), ('node_t', None, None, None, None, None, None), ('legid',
None, None, None, None, None, None), ('version', None, None, None, None, None,
None), ('start', None, None, None, None, None, None), ('title', None, None,
None, None, None, None))
Моя схема является:
CREATE TABLE leg (legid integer primary key, t char(16), year char(16),
no char(16));
CREATE TABLE numbers (
number char(16), legid integer, version integer, start integer,
end integer, prev integer, prev_number char(16), next integer,
next_number char(16), primary key (number, legid, version));
CREATE TABLE position (
segmentid integer, legid integer, version integer, start integer,
primary key (segmentid, legid, version));
CREATE TABLE 'segments'
(segmentid integer primary key, html text, node_t integer);
CREATE TABLE titles (legid integer, segmentid integer, title text,
primary key (legid, segmentid));
CREATE TABLE versions
(legid integer, version integer, primary key (legid, version));
CREATE INDEX idx_numbers_start on numbers (legid, version, start);
Я озадачен тем, что я делаю неправильно. Я попытался выйти/перезапустить как командные строки python, так и sqlite и не вижу, что я делаю неправильно. Это может быть совершенно очевидно.
Для вашей схемы и вашего необработанного запроса вверху я получаю 'Ошибка: неоднозначное имя столбца: segmentid' – msw
Это озадачивает. Ключевое слово USING объединяет имена столбцов в таблице результатов, поэтому не должно быть двусмысленности. Какая версия sqlite3? Как я уже сказал, у меня не было проблем с его использованием и аналогичными запросами из командной строки? –
см. Подробнее ниже ... – msw