2010-05-31 2 views
3

Используя 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 и не вижу, что я делаю неправильно. Это может быть совершенно очевидно.

+0

Для вашей схемы и вашего необработанного запроса вверху я получаю 'Ошибка: неоднозначное имя столбца: segmentid' – msw

+0

Это озадачивает. Ключевое слово USING объединяет имена столбцов в таблице результатов, поэтому не должно быть двусмысленности. Какая версия sqlite3? Как я уже сказал, у меня не было проблем с его использованием и аналогичными запросами из командной строки? –

+0

см. Подробнее ниже ... – msw

ответ

1

раствор (к моей проблеме с помощью библиотеки Python), как представляется, чтобы ввести полностью паразитных имя таблицы:

SELECT legid, version, segmentid, html, node_t, start, number, title 
    from ((segments inner join position using (segmentid)) 
    left outer join titles using (legid, segmentid)) as LT 
    left outer join numbers using (start, legid, version); 

Я думаю, что это так, так это заставить sqlite собирать имена левой стороны внешнего внешнего соединения, одним из которых является «начало», а затем это дает что-то для внешнего внешнего соединения. Это работает для меня - возможно, обновление приведет к появлению большего количества проблем, а не к их удалению, но я перейду через этот мост, когда он придет.

+0

У меня была аналогичная проблема, я решил ее, используя "on" вместо "using" –

0

У вас есть таблица с забавным названием:

CREATE TABLE 'segments' 

Но я не думаю, что это проблема. По желанию, вот мое исполнение запроса с 'segments' таблицы воссозданы в segments:

$ sqlite3 junk.sqlite 
SQLite version 3.6.22 
Enter ".help" for instructions 
Enter SQL statements terminated with a ";" 
sqlite> .schema 
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); 
sqlite> 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); 
Error: ambiguous column name: segmentid 
+0

Копирование и вставка вашей схемы в мой sqlite 3.4.0 и выполнение одного и того же запроса не дают мне ошибку. Что я не думаю, что это должно дать ошибку - если я не упустил что-то. Как вы думаете, это должно быть? Разве это разница между 3,4 и 3,6,22? Теперь я еще больше озадачен, чем был. –

+0

Прошу прощения, что это было отрицательно полезно. Я откровенно вышел из своей глубины с многократными вложенными объединениями, но если бы мне пришлось угадать, sqlite 3.6.22, вероятно, более семантически «правильный» - для ужасно неоднозначного языка, который является SQL. Я не говорю, что вам следует это предпочесть. – msw

0

SQLite версии 3.6.22 - Похоже, что вы должны квалифицировать «неоднозначные имена столбцов» ...

sqlite> 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); 
Error: ambiguous column name: segmentid 

sqlite> select segments.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); 
Error: ambiguous column name: start 

sqlite> select segments.segmentid, node_t, numbers.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); 
sqlite> 

поведение же с SQLite версии 3.6.23.1

+0

Какую версию sqlite вы используете? Возможно, было бы полезно обновить его. –

+0

@Francis, пример выше был с 3.6.22 –

+0

@Francis, пример выше был с 3.6.22 и с 3.6.23.1. –

Смежные вопросы