It would appear Raoul fixed this in: http://bazaar.launchpad.net /~openlp-core/openlp/trunk/revision/2728
** Changed in: openlp Status: Confirmed => Fix Committed ** Changed in: openlp Assignee: Azaziah (suutari-olli) => (unassigned) ** Changed in: openlp Assignee: (unassigned) => Raoul Snyman (raoul-snyman) -- You received this bug notification because you are a member of OpenLP Core, which is subscribed to OpenLP. https://bugs.launchpad.net/bugs/1632567 Title: OpenLP importer can't handle new song songbook DB structure (AttributeError: 'OldSong' object has no attribute 'book') Status in OpenLP: Fix Committed Status in OpenLP 2.4 series: New Bug description: Importing songs that are using the new database format via import menu > OpenLP 2 or First Time Wizard causes traceback. Database structure has been changed from 2.2.1 2.2.1 songs.sqlite does not have a table named "songs_songbooks" Songbook details are stored in “songs” table with fields: “song_book_id” and “song_number” The problem seems to be that the importer tries to look for the songbook data from the "songs" table. This traceback appears on 2.4.4 when trying to import a 2.4 > database into OpenLP 2.4 > Traceback (most recent call last): File "openlp\core\ui\wizard.py", line 216, in on_current_id_changed File "openlp\plugins\songs\forms\songimportform.py", line 351, in perform_wizard File "openlp\plugins\songs\lib\importers\openlp.py", line 224, in do_import AttributeError: 'OldSong' object has no attribute 'book' This also means 2.4> databases are not compatible with 2.2.1. < Is there a benefit in using the new db structure or should this be reverted? If 2.4> database is imported to 2.2.1 this traceback appears and OpenLP crashes with "Fatal error! Openlp returned -1" Traceback (most recent call last): File "c:\Python33\lib\site-packages\sqlalchemy\orm\relationships.py", line 1932, in _determine_joins File "<string>", line 2, in join_condition File "c:\Python33\lib\site-packages\sqlalchemy\sql\selectable.py", line 762, in _join_condition sqlalchemy.exc.NoForeignKeysError: Can't find any foreign key relationships between 'songs' and 'song_books'. During handling of the above exception, another exception occurred: Traceback (most recent call last): File "<string>", line 44, in <module> File "D:\OpenLP_Development\OpenLP_Code\2.2\openlp\core\__init__.py", line 388, in main File "D:\OpenLP_Development\OpenLP_Code\2.2\openlp\core\__init__.py", line 155, in run File "D:\OpenLP_Development\OpenLP_Code\2.2\openlp\core\ui\mainwindow.py", line 668, in first_time File "D:\bzr\Portable_builds\2_2_1\App\OpenLP\plugins\songs\songsplugin.py", line 317, in first_time importer.do_import(progress) File "D:\OpenLP_Development\OpenLP_Code\2.2\openlp\plugins\songs\lib\importers\openlp.py", line 154, in do_import File "c:\Python33\lib\site-packages\sqlalchemy\orm\scoping.py", line 149, in do File "c:\Python33\lib\site-packages\sqlalchemy\orm\session.py", line 1151, in query File "c:\Python33\lib\site-packages\sqlalchemy\orm\query.py", line 106, in __init__ File "c:\Python33\lib\site-packages\sqlalchemy\orm\query.py", line 116, in _set_entities File "c:\Python33\lib\site-packages\sqlalchemy\orm\query.py", line 149, in _set_entity_selectables File "c:\Python33\lib\site-packages\sqlalchemy\orm\query.py", line 2987, in setup_entity File "c:\Python33\lib\site-packages\sqlalchemy\util\langhelpers.py", line 712, in __get__ File "c:\Python33\lib\site-packages\sqlalchemy\orm\mapper.py", line 1856, in _with_polymorphic_mappers File "c:\Python33\lib\site-packages\sqlalchemy\orm\mapper.py", line 2560, in configure_mappers File "c:\Python33\lib\site-packages\sqlalchemy\orm\mapper.py", line 1673, in _post_configure_properties File "c:\Python33\lib\site-packages\sqlalchemy\orm\interfaces.py", line 143, in init File "c:\Python33\lib\site-packages\sqlalchemy\orm\relationships.py", line 1510, in do_init File "c:\Python33\lib\site-packages\sqlalchemy\orm\relationships.py", line 1586, in _setup_join_conditions File "c:\Python33\lib\site-packages\sqlalchemy\orm\relationships.py", line 1849, in __init__ File "c:\Python33\lib\site-packages\sqlalchemy\orm\relationships.py", line 1953, in _determine_joins sqlalchemy.exc.NoForeignKeysError: Could not determine join condition between parent/child tables on relationship OldSong.book - there are no foreign keys linking these tables. Ensure that referencing columns are associated with a ForeignKey or ForeignKeyConstraint, or specify a 'primaryjoin' expression. To manage notifications about this bug go to: https://bugs.launchpad.net/openlp/+bug/1632567/+subscriptions _______________________________________________ Mailing list: https://launchpad.net/~openlp-core Post to : openlp-core@lists.launchpad.net Unsubscribe : https://launchpad.net/~openlp-core More help : https://help.launchpad.net/ListHelp