Shadowhelix:Datenbank/Umsetzung SQL: Unterschied zwischen den Versionen

Aus Shadowhelix
Zur Navigation springen Zur Suche springen
Keine Bearbeitungszusammenfassung
Keine Bearbeitungszusammenfassung
Zeile 5: Zeile 5:
<pre>
<pre>
CREATE TABLE source(
CREATE TABLE source(
id_source      INTEGER(0) NOT NULL
id_source      TEXT NOT NULL
,description  TEXT NOT NULL
,description  TEXT NOT NULL
,language_code TEXT NOT NULL
,language_code TEXT NOT NULL
,type          TEXT
,type          TEXT
,id_reference  TEXT
);
);


CREATE TABLE source_catalog(
CREATE TABLE source_catalog(
id_source    INTEGER(0) NOT NULL
id_source    TEXT NOT NULL
,id_part      TEXT
,id_part      TEXT
,issue        TEXT
,issue        TEXT
Zeile 18: Zeile 19:
,catalog      TEXT
,catalog      TEXT
,key          TEXT
,key          TEXT
,id_reference TEXT
);
CREATE TABLE source_date(
id_source    TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version  TEXT
,year        TEXT
,month        TEXT
,day          TEXT
,id_reference TEXT
);
CREATE TABLE source_date_ingame(
id_source          TEXT NOT NULL
,id_part          TEXT
,issue            TEXT
,id_version        TEXT
,range_start_year  TEXT
,range_start_month TEXT
,range_start_day  TEXT
,range_end_year    TEXT
,range_end_month  TEXT
,range_end_day    TEXT
,id_reference      TEXT
);
CREATE TABLE source_edition(
id_source    TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version  TEXT
,edition      TEXT
,id_reference TEXT
);
CREATE TABLE source_page_number(
id_source    TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version  TEXT
,page_number  TEXT
,id_reference TEXT
);
CREATE TABLE source_part(
id_source    TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version  TEXT
,description  TEXT
,id_reference TEXT
);
);


CREATE TABLE source_title(
CREATE TABLE source_title(
id_source   INTEGER(0) NOT NULL
id_source     TEXT NOT NULL
,id_part     TEXT
,id_part     TEXT
,issue       TEXT
,issue       TEXT
,id_version TEXT
,id_version   TEXT
,prefix     TEXT
,prefix       TEXT
,pre_article TEXT
,pre_article TEXT
,title       TEXT
,title       TEXT
,subtitle   TEXT
,subtitle     TEXT
,id_reference TEXT
);
);


CREATE TABLE source_translated(
CREATE TABLE source_translated(
id_source            INTEGER(0) NOT NULL
id_source            TEXT NOT NULL
,id_source_original  INTEGER(0) NOT NULL
,id_source_original  TEXT NOT NULL
,partial_translation TEXT
,partial_translation TEXT
,id_reference        TEXT
);
);


Zeile 92: Zeile 148:
CREATE TABLE contribution_illustration(
CREATE TABLE contribution_illustration(
id_contributor  TEXT NOT NULL
id_contributor  TEXT NOT NULL
,id_illustration INTEGER(0)
,id_illustration TEXT
,id_reference    TEXT
,id_reference    TEXT
);
);
Zeile 103: Zeile 159:


CREATE TABLE illustration_catalog(
CREATE TABLE illustration_catalog(
id_illustration INTEGER(0) NOT NULL
id_illustration TEXT NOT NULL
,catalog        TEXT
,catalog        TEXT
,key            TEXT
,key            TEXT
,id_reference  TEXT
);
);


CREATE TABLE illustration_source(
CREATE TABLE illustration_source(
id_illustration  INTEGER(0) NOT NULL
id_illustration  TEXT NOT NULL
,id_source      INTEGER(0) NOT NULL
,id_source      TEXT NOT NULL
,id_part        TEXT
,id_part        TEXT
,issue          TEXT
,issue          TEXT
Zeile 118: Zeile 175:
,position        TEXT
,position        TEXT
,modification    TEXT
,modification    TEXT
,id_reference    TEXT
);
);


CREATE TABLE illustration_type(
CREATE TABLE illustration_type(
id_illustration INTEGER(0) NOT NULL
id_illustration TEXT NOT NULL
,type          TEXT NOT NULL
,type          TEXT NOT NULL
,id_reference  TEXT
);
);


CREATE TABLE illustration_weblink(
CREATE TABLE illustration_weblink(
id_illustration INTEGER(0) NOT NULL
id_illustration TEXT NOT NULL
,web_link      TEXT
,web_link      TEXT
,direct_link    TEXT
,direct_link    TEXT
,id_reference  TEXT
);
);


CREATE TABLE index_product(
CREATE TABLE index_product(
id_product      INTEGER(0) NOT NULL
id_product      INTEGER(0) NOT NULL
,id_source      INTEGER(0)
,id_source      TEXT
,id_part        TEXT
,id_part        TEXT
,issue          TEXT
,issue          TEXT
Zeile 139: Zeile 199:
,page_reference  TEXT
,page_reference  TEXT
,entry_reference TEXT
,entry_reference TEXT
,id_reference    TEXT
);
);


CREATE TABLE index_illustration_person(
CREATE TABLE index_illustration_person(
id_person        INTEGER(0) NOT NULL
id_person        TEXT NOT NULL
,id_illustration INTEGER(0) NOT NULL
,id_illustration TEXT NOT NULL
,id_reference    TEXT
);
);


Zeile 182: Zeile 243:
,language_code TEXT
,language_code TEXT
,name          TEXT
,name          TEXT
);
CREATE TABLE object_group(
id_object    TEXT NOT NULL
,group_name  TEXT NOT NULL
,id_reference TEXT
);
CREATE TABLE object_name(
id_object      TEXT NOT NULL
,language_code TEXT
,name          TEXT
,id_reference  TEXT
);
);


CREATE TABLE person(
CREATE TABLE person(
id_person   INTEGER(0) NOT NULL
id_person     TEXT NOT NULL
,description TEXT NOT NULL
,description TEXT NOT NULL
,sex         TEXT
,sex         TEXT
,id_reference TEXT
);
);


Zeile 223: Zeile 298:
.import ShxDB_source.txt source
.import ShxDB_source.txt source
.import ShxDB_source_catalog.txt source_catalog
.import ShxDB_source_catalog.txt source_catalog
.import ShxDB_source_date.txt source_date
.import ShxDB_source_date_ingame.txt source_date_ingame
.import ShxDB_source_edition.txt source_edition
.import ShxDB_source_page_number.txt source_page_number
.import ShxDB_source_part.txt source_part
.import ShxDB_source_title.txt source_title
.import ShxDB_source_title.txt source_title
.import ShxDB_source_translated.txt source_translated
.import ShxDB_source_translated.txt source_translated
Zeile 234: Zeile 314:
.import ShxDB_index_product.txt index_product
.import ShxDB_index_product.txt index_product
.import ShxDB_index_illustration_person.txt index_illustration_person
.import ShxDB_index_illustration_person.txt index_illustration_person
.import ShxDB_corporation_name.txt corporation_name
.import ShxDB_corporation_name.txt corporation_name
.import ShxDB_corporation_ownership.txt corporation_ownership
.import ShxDB_corporation_ownership.txt corporation_ownership
.import ShxDB_object_group.txt object_group
.import ShxDB_object_name.txt object_name
.import ShxDB_person.txt person
.import ShxDB_person.txt person
.import ShxDB_product_name.txt product_name
.import ShxDB_product_name.txt product_name

Version vom 8. Mai 2016, 17:08 Uhr

Datenbankstruktur

Skript für Tabellenerstellung:

CREATE TABLE source(
id_source      TEXT NOT NULL
,description   TEXT NOT NULL
,language_code TEXT NOT NULL
,type          TEXT
,id_reference  TEXT
);

CREATE TABLE source_catalog(
id_source     TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version   TEXT
,catalog      TEXT
,key          TEXT
,id_reference TEXT
);

CREATE TABLE source_date(
id_source     TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version   TEXT
,year         TEXT
,month        TEXT
,day          TEXT
,id_reference TEXT
);

CREATE TABLE source_date_ingame(
id_source          TEXT NOT NULL
,id_part           TEXT
,issue             TEXT
,id_version        TEXT
,range_start_year  TEXT
,range_start_month TEXT
,range_start_day   TEXT
,range_end_year    TEXT
,range_end_month   TEXT
,range_end_day     TEXT
,id_reference      TEXT
);

CREATE TABLE source_edition(
id_source     TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version   TEXT
,edition      TEXT
,id_reference TEXT
);

CREATE TABLE source_page_number(
id_source     TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version   TEXT
,page_number  TEXT
,id_reference TEXT
);

CREATE TABLE source_part(
id_source     TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version   TEXT
,description  TEXT
,id_reference TEXT
);

CREATE TABLE source_title(
id_source     TEXT NOT NULL
,id_part      TEXT
,issue        TEXT
,id_version   TEXT
,prefix       TEXT
,pre_article  TEXT
,title        TEXT
,subtitle     TEXT
,id_reference TEXT
);

CREATE TABLE source_translated(
id_source            TEXT NOT NULL
,id_source_original  TEXT NOT NULL
,partial_translation TEXT
,id_reference        TEXT
);

CREATE TABLE contributor(
id_contributor   TEXT NOT NULL
,surname         TEXT
,surname_suffix  TEXT
,forename_first  TEXT
,forename_second TEXT
,forename_third  TEXT
,year_birth      TEXT
,year_death      TEXT
,sex             CHAR(1)
,id_reference    TEXT
);

CREATE TABLE contributor_catalog(
id_contributor          TEXT NOT NULL
,catalog                TEXT
,key                    TEXT
,archive_copy_timestamp INTEGER(0)
,id_reference           TEXT
);

CREATE TABLE contributor_referenced_name(
id_contributor   TEXT NOT NULL
,referenced_name TEXT NOT NULL
,id_reference    TEXT
);

CREATE TABLE contributor_weblink(
id_contributor          TEXT NOT NULL
,url                    TEXT NOT NULL
,archive_copy_timestamp INTEGER(0)
,id_reference           TEXT
);

CREATE TABLE contributor_weblink_hosting_service(
id_contributor          TEXT NOT NULL
,hosting_service        TEXT NOT NULL
,account_name           TEXT NOT NULL
,archive_copy_timestamp INTEGER(0)
,id_reference           TEXT
);

CREATE TABLE contribution(
id_contributor        TEXT NOT NULL
,id_source            TEXT NOT NULL
,id_part              TEXT
,issue                TEXT
,id_version           TEXT
,type_of_contribution TEXT NOT NULL
,uncredited           CHAR(1)
,id_reference         TEXT
);

CREATE TABLE contribution_illustration(
id_contributor   TEXT NOT NULL
,id_illustration TEXT
,id_reference    TEXT
);

CREATE TABLE contribution_text(
id_contributor TEXT NOT NULL
,id_text       TEXT NOT NULL
,id_reference  TEXT
);

CREATE TABLE illustration_catalog(
id_illustration TEXT NOT NULL
,catalog        TEXT
,key            TEXT
,id_reference   TEXT
);

CREATE TABLE illustration_source(
id_illustration  TEXT NOT NULL
,id_source       TEXT NOT NULL
,id_part         TEXT
,issue           TEXT
,id_version      TEXT
,page_reference  TEXT
,entry_reference TEXT
,position        TEXT
,modification    TEXT
,id_reference    TEXT
);

CREATE TABLE illustration_type(
id_illustration TEXT NOT NULL
,type           TEXT NOT NULL
,id_reference   TEXT
);

CREATE TABLE illustration_weblink(
id_illustration TEXT NOT NULL
,web_link       TEXT
,direct_link    TEXT
,id_reference   TEXT
);

CREATE TABLE index_product(
id_product       INTEGER(0) NOT NULL
,id_source       TEXT
,id_part         TEXT
,issue           TEXT
,id_version      TEXT
,page_reference  TEXT
,entry_reference TEXT
,id_reference    TEXT
);

CREATE TABLE index_illustration_person(
id_person        TEXT NOT NULL
,id_illustration TEXT NOT NULL
,id_reference    TEXT
);

CREATE TABLE corporation_name(
id_corporation INTEGER(0) NOT NULL
,language_code TEXT
,short_name    TEXT
,full_name     TEXT
,abbreviation  TEXT
);

CREATE TABLE corporation_ownership(
id_corporation         INTEGER(0) NOT NULL
,id_corporation_owner  INTEGER(0)
,id_organisation_owner INTEGER(0)
,id_person_owner       INTEGER(0)
,fraction              TEXT
,from_year             TEXT
,from_month            TEXT
,to_year               TEXT
,to_month              TEXT
);

CREATE TABLE product_name(
id_product     INTEGER(0) NOT NULL
,language_code TEXT
,name          TEXT
);

CREATE TABLE product_type(
id_product   INTEGER(0) NOT NULL
,id_type     INTEGER(0)
);

CREATE TABLE type(
id_type        INTEGER(0) NOT NULL
,language_code TEXT
,name          TEXT
);

CREATE TABLE object_group(
id_object     TEXT NOT NULL
,group_name   TEXT NOT NULL
,id_reference TEXT
);

CREATE TABLE object_name(
id_object      TEXT NOT NULL
,language_code TEXT
,name          TEXT
,id_reference  TEXT
);

CREATE TABLE person(
id_person     TEXT NOT NULL
,description  TEXT NOT NULL
,sex          TEXT
,id_reference TEXT
);

CREATE TABLE shadow_matrix_user(
id_user    INTEGER(0) NOT NULL
,id_person INTEGER(0)
,name      TEXT
);

CREATE TABLE shadow_matrix_shadowtalk_source(
id_user          INTEGER(0) NOT NULL
,id_source       INTEGER(0) NOT NULL
,issue           TEXT
,page_reference  TEXT
,entry_reference TEXT
);

Beispielimplementierung - SQLite

Anleitung - Erstellung der Datenbank

Voraussetzung: SQLite ist installiert.
  • Datenbank-Dateien herunterladen.
  • Obenstehendes Skript in die Datei create_tables.sql kopieren.
  • Import-Skript in die Datei import.sql schreiben. Inhalt (kürzen, falls nicht alle Daten eingefügt werden müssen):
.separator "\t"
.import ShxDB_contributor.txt contributor
.import ShxDB_contributor_contributors_catalog.txt contributor_catalog
.import ShxDB_contributor_referenced_name contributor_referenced_name
.import ShxDB_contributor_weblink.txt contributor_weblink
.import ShxDB_contributor_weblink_hosting_service.txt contributor_weblink_hosting_service
.import ShxDB_source.txt source
.import ShxDB_source_catalog.txt source_catalog
.import ShxDB_source_date.txt source_date
.import ShxDB_source_date_ingame.txt source_date_ingame
.import ShxDB_source_edition.txt source_edition
.import ShxDB_source_page_number.txt source_page_number
.import ShxDB_source_part.txt source_part
.import ShxDB_source_title.txt source_title
.import ShxDB_source_translated.txt source_translated
.import ShxDB_contribution.txt contribution
.import ShxDB_contribution_illustration.txt contribution_illustration
.import ShxDB_contribution_text.txt contribution_text
.import ShxDB_illustration_catalog.txt illustration_catalog
.import ShxDB_illustration_source.txt illustration_source
.import ShxDB_illustration_type.txt illustration_type
.import ShxDB_illustration_weblink.txt illustration_weblink
.import ShxDB_index_product.txt index_product
.import ShxDB_index_illustration_person.txt index_illustration_person

.import ShxDB_corporation_name.txt corporation_name
.import ShxDB_corporation_ownership.txt corporation_ownership
.import ShxDB_object_group.txt object_group
.import ShxDB_object_name.txt object_name
.import ShxDB_person.txt person
.import ShxDB_product_name.txt product_name
.import ShxDB_product_type.txt product_type
.import ShxDB_type.txt type
.import ShxDB_shadow_matrix_user.txt shadow_matrix_user
.import ShxDB_shadow_matrix_shadowtalk_source.txt shadow_matrix_shadowtalk_source
  • Alle Dateien in ein Verzeichnis zusammenführen.
  • Neue Datenbank anlegen ggf. systemabhängig aber normalerweise durch Aufruf des SQLite-Kommandos mit Datenbankname, z.B.
> sqlite shx.db
  • In SQlite die Tabellen durch Ausführen von create_tables.sql erstellen.
sqlite> .read create_tables.sql
  • In SQlite den Inhalt der Datenbankdateien durch Ausführen von import.sql in die Tabellen importieren.
sqlite> .read import.sql