mirror of
				https://github.com/johrpan/musicus_mobile.git
				synced 2025-10-26 10:47:25 +01:00 
			
		
		
		
	database: Store work parts in seperate table
This commit is contained in:
		
							parent
							
								
									2d96d2fec8
								
							
						
					
					
						commit
						9bd0348f35
					
				
					 3 changed files with 64 additions and 41 deletions
				
			
		|  | @ -97,17 +97,18 @@ class Database extends _$Database { | ||||||
|   Future<WorkInfo> getWorkInfo(Work work) async { |   Future<WorkInfo> getWorkInfo(Work work) async { | ||||||
|     final id = work.id; |     final id = work.id; | ||||||
| 
 | 
 | ||||||
|     final composers = await composersByWork(id).get(); |     final composers = await partComposersByWork(id).get(); | ||||||
|  |     composers.insert(0, await personById(work.composer).getSingle()); | ||||||
|     final instruments = await instrumentsByWork(id).get(); |     final instruments = await instrumentsByWork(id).get(); | ||||||
| 
 | 
 | ||||||
|     final List<PartInfo> parts = []; |     final List<PartInfo> parts = []; | ||||||
|     for (final part in await workParts(id).get()) { |     for (final part in await partsByWork(id).get()) { | ||||||
|       parts.add(PartInfo( |       parts.add(PartInfo( | ||||||
|         work: part, |         part: part, | ||||||
|         composer: part.composer != null |         composer: part.composer != null | ||||||
|             ? await personById(part.composer).getSingle() |             ? await personById(part.composer).getSingle() | ||||||
|             : null, |             : null, | ||||||
|         instruments: await instrumentsByWork(id).get(), |         instruments: await instrumentsByWorkPart(part.id).get(), | ||||||
|       )); |       )); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -163,32 +164,35 @@ class Database extends _$Database { | ||||||
|       // deleted automatically due to their foreign key constraints. |       // deleted automatically due to their foreign key constraints. | ||||||
|       await deleteWork(workId); |       await deleteWork(workId); | ||||||
| 
 | 
 | ||||||
|       /// Insert instrumentations for a work. |  | ||||||
|       /// |  | ||||||
|       /// At the moment, this will also update all provided instruments, even |  | ||||||
|       /// if they were already there previously. |  | ||||||
|       Future<void> insertInstrumentations( |  | ||||||
|           int workId, List<Instrument> instruments) async { |  | ||||||
|         for (final instrument in instruments) { |  | ||||||
|           await updateInstrument(instrument); |  | ||||||
|           await into(instrumentations).insert(Instrumentation( |  | ||||||
|             work: workId, |  | ||||||
|             instrument: instrument.id, |  | ||||||
|           )); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
|       // This will also include the composers of the work's parts. |       // This will also include the composers of the work's parts. | ||||||
|       for (final person in workInfo.composers) { |       for (final person in workInfo.composers) { | ||||||
|         await updatePerson(person); |         await updatePerson(person); | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       await into(works).insert(workInfo.work); |       await into(works).insert(workInfo.work); | ||||||
|       await insertInstrumentations(workId, workInfo.instruments); | 
 | ||||||
|  |       // At the moment, this will also update all provided instruments, even if | ||||||
|  |       // they were already there previously. | ||||||
|  |       for (final instrument in workInfo.instruments) { | ||||||
|  |         await updateInstrument(instrument); | ||||||
|  |         await into(instrumentations).insert(Instrumentation( | ||||||
|  |           work: workId, | ||||||
|  |           instrument: instrument.id, | ||||||
|  |         )); | ||||||
|  |       } | ||||||
| 
 | 
 | ||||||
|       for (final partInfo in workInfo.parts) { |       for (final partInfo in workInfo.parts) { | ||||||
|         await into(works).insert(partInfo.work); |         final part = partInfo.part; | ||||||
|         await insertInstrumentations(partInfo.work.id, partInfo.instruments); | 
 | ||||||
|  |         await into(workParts).insert(part); | ||||||
|  | 
 | ||||||
|  |         for (final instrument in workInfo.instruments) { | ||||||
|  |           await updateInstrument(instrument); | ||||||
|  |           await into(partInstrumentations).insert(PartInstrumentation( | ||||||
|  |             workPart: part.id, | ||||||
|  |             instrument: instrument.id, | ||||||
|  |           )); | ||||||
|  |         } | ||||||
|       } |       } | ||||||
|     }); |     }); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  | @ -14,9 +14,7 @@ CREATE TABLE instruments ( | ||||||
| CREATE TABLE works ( | CREATE TABLE works ( | ||||||
|     id INTEGER NOT NULL PRIMARY KEY, |     id INTEGER NOT NULL PRIMARY KEY, | ||||||
|     composer INTEGER REFERENCES persons(id) ON DELETE SET NULL, |     composer INTEGER REFERENCES persons(id) ON DELETE SET NULL, | ||||||
|     title TEXT NOT NULL, |     title TEXT NOT NULL | ||||||
|     part_of INTEGER REFERENCES works(id) ON DELETE CASCADE, |  | ||||||
|     part_index INTEGER |  | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| CREATE TABLE instrumentations ( | CREATE TABLE instrumentations ( | ||||||
|  | @ -24,6 +22,19 @@ CREATE TABLE instrumentations ( | ||||||
|     instrument INTEGER NOT NULL REFERENCES instruments(id) ON DELETE CASCADE |     instrument INTEGER NOT NULL REFERENCES instruments(id) ON DELETE CASCADE | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
|  | CREATE TABLE work_parts ( | ||||||
|  |     id INTEGER NOT NULL PRIMARY KEY, | ||||||
|  |     composer INTEGER REFERENCES persons(id) ON DELETE SET NULL, | ||||||
|  |     title TEXT NOT NULL, | ||||||
|  |     part_of INTEGER NOT NULL REFERENCES works(id) ON DELETE CASCADE, | ||||||
|  |     part_index INTEGER NOT NULL | ||||||
|  | ); | ||||||
|  | 
 | ||||||
|  | CREATE TABLE part_instrumentations ( | ||||||
|  |     work_part INTEGER NOT NULL REFERENCES works(id) ON DELETE CASCADE, | ||||||
|  |     instrument INTEGER NOT NULL REFERENCES instruments(id) ON DELETE CASCADE | ||||||
|  | ); | ||||||
|  | 
 | ||||||
| CREATE TABLE ensembles ( | CREATE TABLE ensembles ( | ||||||
|     id INTEGER NOT NULL PRIMARY KEY, |     id INTEGER NOT NULL PRIMARY KEY, | ||||||
|     name TEXT NOT NULL |     name TEXT NOT NULL | ||||||
|  | @ -66,29 +77,37 @@ SELECT * FROM instruments WHERE id = :id LIMIT 1; | ||||||
| workById: | workById: | ||||||
| SELECT * FROM works WHERE id = :id LIMIT 1; | SELECT * FROM works WHERE id = :id LIMIT 1; | ||||||
| 
 | 
 | ||||||
| workParts: | partsByWork: | ||||||
| SELECT * FROM works WHERE part_of = :id ORDER BY part_index; | SELECT * FROM work_parts WHERE part_of = :id ORDER BY part_index; | ||||||
| 
 | 
 | ||||||
| worksByComposer: | worksByComposer: | ||||||
| SELECT DISTINCT A.* FROM works A LEFT JOIN works B ON A.id = B.part_of | SELECT DISTINCT works.* FROM works | ||||||
|     WHERE (A.part_of IS NULL AND A.composer = :id) OR B.composer = :id |     JOIN work_parts ON work_parts.part_of = works.id | ||||||
|     ORDER BY A.title LIMIT :limit OFFSET :offset; |     WHERE works.composer = :id OR work_parts.composer = :id | ||||||
|  |     ORDER BY works.title LIMIT :limit OFFSET :offset; | ||||||
| 
 | 
 | ||||||
| searchWorksByComposer: | searchWorksByComposer: | ||||||
| SELECT DISTINCT A.* FROM works A LEFT JOIN works B ON A.id = B.part_of | SELECT DISTINCT works.* FROM works | ||||||
|     WHERE ((A.part_of IS NULL AND A.composer = :id) OR B.composer = :id) |     JOIN work_parts ON work_parts.part_of = works.id | ||||||
|     AND A.title LIKE :search ORDER BY A.title LIMIT :limit OFFSET :offset; |     WHERE (works.composer = :id OR work_parts.composer = :id) | ||||||
|  |     AND works.title LIKE :search | ||||||
|  |     ORDER BY works.title LIMIT :limit OFFSET :offset; | ||||||
| 
 | 
 | ||||||
| composersByWork: | partComposersByWork: | ||||||
| SELECT DISTINCT persons.* FROM persons | SELECT DISTINCT persons.* FROM persons | ||||||
|     JOIN works ON works.composer = persons.id |     JOIN work_parts ON work_parts.composer = persons.id | ||||||
|     WHERE works.id = :id OR works.part_of = :id; |     WHERE work_parts.part_of = :id; | ||||||
| 
 | 
 | ||||||
| instrumentsByWork: | instrumentsByWork: | ||||||
| SELECT instruments.* FROM instrumentations | SELECT instruments.* FROM instrumentations | ||||||
|     JOIN instruments ON instrumentations.instrument = instruments.id |     JOIN instruments ON instrumentations.instrument = instruments.id | ||||||
|     WHERE instrumentations.work = :workId; |     WHERE instrumentations.work = :workId; | ||||||
| 
 | 
 | ||||||
|  | instrumentsByWorkPart: | ||||||
|  | SELECT instruments.* FROM part_instrumentations | ||||||
|  |     JOIN instruments ON part_instrumentations.instrument = instruments.id | ||||||
|  |     WHERE part_instrumentations.work_part = :id; | ||||||
|  | 
 | ||||||
| allEnsembles: | allEnsembles: | ||||||
| SELECT * FROM ensembles ORDER BY name LIMIT :limit OFFSET :offset; | SELECT * FROM ensembles ORDER BY name LIMIT :limit OFFSET :offset; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ import 'database.dart'; | ||||||
| /// A bundle of all available information on a work part. | /// A bundle of all available information on a work part. | ||||||
| class PartInfo { | class PartInfo { | ||||||
|   /// The work part itself. |   /// The work part itself. | ||||||
|   final Work work; |   final WorkPart part; | ||||||
| 
 | 
 | ||||||
|   /// A list of instruments. |   /// A list of instruments. | ||||||
|   /// |   /// | ||||||
|  | @ -16,13 +16,13 @@ class PartInfo { | ||||||
|   final Person composer; |   final Person composer; | ||||||
| 
 | 
 | ||||||
|   PartInfo({ |   PartInfo({ | ||||||
|     this.work, |     this.part, | ||||||
|     this.instruments, |     this.instruments, | ||||||
|     this.composer, |     this.composer, | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   factory PartInfo.fromJson(Map<String, dynamic> json) => PartInfo( |   factory PartInfo.fromJson(Map<String, dynamic> json) => PartInfo( | ||||||
|         work: Work.fromJson(json['work']), |         part: WorkPart.fromJson(json['part']), | ||||||
|         instruments: json['instruments'] |         instruments: json['instruments'] | ||||||
|             .map<Instrument>((j) => Instrument.fromJson(j)) |             .map<Instrument>((j) => Instrument.fromJson(j)) | ||||||
|             .toList(), |             .toList(), | ||||||
|  | @ -31,7 +31,7 @@ class PartInfo { | ||||||
|       ); |       ); | ||||||
| 
 | 
 | ||||||
|   Map<String, dynamic> toJson() => { |   Map<String, dynamic> toJson() => { | ||||||
|         'work': work.toJson(), |         'part': part.toJson(), | ||||||
|         'instruments': instruments.map((i) => i.toJson()).toList(), |         'instruments': instruments.map((i) => i.toJson()).toList(), | ||||||
|         'composers': composer?.toJson(), |         'composers': composer?.toJson(), | ||||||
|       }; |       }; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Elias Projahn
						Elias Projahn