====== Import nově přijatých studentů do Evergreenu====== ===== Export nových studentů z ISu ===== Studijní agenda > hromadný výběr > Vybrat dotaz //"Jabok: Přijat nezapsán(stav 88)"//. Dotaz je možné také zadat ručně: [fak JA10][stud_stav 88] Po vypsání výsledků dotazu (seznam studentů) použít odkaz //"Zpět na Manipulace se seznamem vybraných studentů"// Poté v sekci Studijní - výběr studentů a operací vybrat "Tisky" > Seznamy, sestavy (návod k sestavám, Prezentátoru) > Ve "Výběru z připravených popisů sestav" vybrat popis "JABOK: Knihovna: import nově přijatých studentů". Popis lze vložit také ručně: ,,,,MAILING,,,,,,111,3,,103,2,,false,2019-09-01, **V sestavě je nutné změnit datum expirace čtenářského účtu na 1.9. následujícího roku** (v uložené sestavě je to datum 2019-09-01, které je ve výstupu posledním údajem na řádku) Jako formu výstupu zvolit //"Textový soubor s kódováním UTF-8 (Unicode)"// ===== Import studentů do Evergreenu ===== ==== Vytvoření tabulky s novými čtenáři ==== CREATE TABLE jabok_students ( student_id integer, barcode text, last_name text, first_name text, email text, address_type text DEFAULT 'MAILING', street1 text, street2 text, city text, country text DEFAULT 'Česká republika', postal_code text, phone text, profile_id integer, ident_type integer, ident_value text, home_ou integer, net_access_level integer, date_of_birth date, active boolean, expire_date timestamp, stat_cat integer, stat_cat_entry integer); ==== Kopírování dat z CSV ==== COPY jabok_students (barcode, last_name, first_name, email, address_type, street1, city, country, postal_code, phone, profile_id, ident_type, ident_value, home_ou, net_access_level, date_of_birth, active, expire_date, stat_cat, stat_cat_entry) FROM '/home/opensrf/Ctenari/data_pro_import.csv' WITH CSV HEADER; ==== Nalezení duplicit dle jména a data narození ==== SELECT actor.usr.first_given_name, actor.usr.family_name, actor.usr.dob, jabok_students.first_name, jabok_students.last_name, jabok_students.barcode FROM jabok_students INNER JOIN actor.usr ON jabok_students.date_of_birth IS NOT DISTINCT FROM actor.usr.dob AND actor.usr.first_given_name IS NOT DISTINCT FROM jabok_students.first_name; === Výstup s duplicitními hodnotami === first_given_name | family_name | dob | first_name | last_name | barcode ------------------+-------------+------------+------------+-------------+--------- Adam | Novák | 1991-11-30 | Adam | Novák | 1234 Anna | Nováčková | 1996-05-07 | Anna | Nováčková | 2345 Alice | Nováková | 1979-07-07 | Alice | Nováková | 3456 Amos | Nováček | 1973-04-11 | Amos | Nováček | 4567 (4 rows) ==== Smazání všech vypsaných duplicitních čtenářů ==== DELETE FROM jabok_students USING actor.usr WHERE jabok_students.date_of_birth IS NOT DISTINCT FROM actor.usr.dob AND actor.usr.first_given_name IS NOT DISTINCT FROM jabok_students.first_name; ==== Vložení do tabulky actor.usr ==== Pozn.: do tabulky musí být vloženo heslo INSERT INTO actor.usr ( profile, usrname, passwd, email, ident_type, ident_value, first_given_name, family_name, day_phone, home_ou, claims_returned_count, net_access_level, dob, expire_date, active) SELECT profile_id, barcode, email, email, ident_type, ident_value, first_name, last_name, phone, home_ou, 0, net_access_level, date_of_birth, expire_date, active FROM jabok_students; ==== Vložení úvodního čárového kódu (barcode) ==== Pozn.: číslo pro "barcode" je totožné se "student id") INSERT INTO actor.card (usr, barcode) SELECT actor.usr.id, jabok_students.barcode FROM jabok_students INNER JOIN actor.usr ON jabok_students.barcode = actor.usr.usrname; UPDATE actor.usr AS au SET card = ac.id FROM actor.card AS ac WHERE au.id=ac.usr AND au.id between 2089 AND 2184; INSERT INTO actor.usr_address (usr, street1, city, state, country, post_code, address_type) SELECT actor.usr.id, jabok_students.street1, jabok_students.city, jabok_students.country, jabok_students.country, jabok_students.postal_code, jabok_students.address_type FROM jabok_students INNER JOIN actor.usr ON jabok_students.barcode = actor.usr.usrname; UPDATE actor.usr SET expire_date = '2018-09-01 00:00:00+02' where id between 2089 AND 2184;