Changes between Initial Version and Version 1 of appdevelopment


Ignore:
Timestamp:
01/31/26 13:18:49 (31 hours ago)
Author:
231175
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • appdevelopment

    v1 v1  
     1= Напреден Апликативен Развој =
     2
     3== Трансакции ==
     4
     5=== Креирање на курс ===
     6{{{
     7BEGIN;
     8
     9DROP TABLE IF EXISTS temp_course_id;
     10DROP TABLE IF EXISTS temp_course_version_id;
     11DROP TABLE IF EXISTS temp_course_translate_id;
     12DROP TABLE IF EXISTS temp_course_content_id;
     13DROP TABLE IF EXISTS temp_course_lecture_id;
     14DROP TABLE IF EXISTS temp_tag_id;
     15
     16CREATE TEMP TABLE temp_course_id (id BIGINT);
     17CREATE TEMP TABLE temp_course_version_id (id BIGINT);
     18CREATE TEMP TABLE temp_course_translate_id (id BIGINT, language VARCHAR(2));
     19CREATE TEMP TABLE temp_course_content_id (id BIGINT);
     20CREATE TEMP TABLE temp_course_lecture_id (id BIGINT);
     21CREATE TEMP TABLE temp_tag_id (id BIGINT, type VARCHAR(50));
     22
     23WITH new_course AS (
     24    INSERT INTO course (image_url, difficulty, duration_minutes, price, color)
     25    VALUES ('https://example.com/image.png', 'INTERMEDIATE', 120, 50, '#008CC2')
     26    RETURNING id
     27)
     28INSERT INTO temp_course_id (id)
     29SELECT id FROM new_course;
     30
     31WITH new_course_version AS (
     32    INSERT INTO course_version (course_id)
     33    SELECT id FROM temp_course_id
     34    RETURNING id
     35)
     36INSERT INTO temp_course_version_id (id)
     37SELECT id FROM new_course_version;
     38
     39WITH new_course_translate_en AS (
     40    INSERT INTO course_translate (language, title_short, title, description_short, description, description_long, course_id)
     41    SELECT 'en', 'Advanced Sales', 'Advanced Sales For Senior Salesman', 'Short desc', 'Normal desc', 'Long desc', id FROM temp_course_id
     42    RETURNING id, language
     43)
     44INSERT INTO temp_course_translate_id (id, language)
     45SELECT id, language FROM new_course_translate_en;
     46
     47WITH new_course_translate_mk AS (
     48    INSERT INTO course_translate (language, title_short, title, description_short, description, description_long, course_id)
     49    SELECT 'mk', 'Напредна Продажба', 'Напредна Продажба за Сениор Продавачи', 'Кратка дескрипција', 'Нормална дескрипција', 'Долга дескрипција', id FROM temp_course_id
     50    RETURNING id, language
     51)
     52INSERT INTO temp_course_translate_id (id, language)
     53SELECT id, language FROM new_course_translate_mk;
     54
     55WITH new_course_content AS (
     56    INSERT INTO course_content (position, course_version_id)
     57    SELECT 1, id FROM temp_course_version_id
     58    RETURNING id
     59)
     60INSERT INTO temp_course_content_id (id)
     61SELECT id FROM new_course_content;
     62
     63INSERT INTO course_content_translate (title, language, course_content_id)
     64SELECT 'Module 1: Sales Strategies', 'en', id FROM temp_course_content_id;
     65
     66INSERT INTO course_content_translate (title, language, course_content_id)
     67SELECT 'Модул 1: Продажни Стратегии', 'mk', id FROM temp_course_content_id;
     68
     69WITH new_course_lecture AS (
     70    INSERT INTO course_lecture (duration_minutes, position, content_type, course_content_id)
     71    SELECT 30, 1, 'video', id FROM temp_course_content_id
     72    RETURNING id
     73)
     74INSERT INTO temp_course_lecture_id (id)
     75SELECT id FROM new_course_lecture;
     76
     77INSERT INTO course_lecture_translate (title, language, content_file_name, description, content_text, course_lecture_id)
     78SELECT 'Lecture 1: Intro', 'en', 'lecture1.mp4', 'Introduction to advanced sales', 'Video text content', id
     79FROM temp_course_lecture_id;
     80
     81INSERT INTO course_lecture_translate (title, language, content_file_name, description, content_text, course_lecture_id)
     82SELECT 'Предавање 1: Вовед', 'mk', 'lecture1.mp4', 'Вовед во напредна продажба', 'Тмп', id
     83FROM temp_course_lecture_id;
     84
     85WITH new_tags AS (
     86    INSERT INTO tag (type)
     87    VALUES ('skill'), ('interest')
     88    RETURNING id, type
     89)
     90INSERT INTO temp_tag_id (id, type)
     91SELECT id, type FROM new_tags;
     92
     93INSERT INTO tag_translate (language, value, tag_id)
     94SELECT 'en', CASE type WHEN 'skill' THEN 'Skill' WHEN 'interest' THEN 'Interest' END, id FROM temp_tag_id;
     95
     96INSERT INTO tag_translate (language, value, tag_id)
     97SELECT 'mk', CASE type WHEN 'skill' THEN 'Вештина' WHEN 'interest' THEN 'Интерес' END, id FROM temp_tag_id;
     98
     99INSERT INTO course_tag (tag_id, course_id)
     100SELECT t.id, c.id
     101FROM temp_tag_id t
     102CROSS JOIN temp_course_id c;
     103
     104INSERT INTO expert_course (course_id, expert_id)
     105SELECT id, 1
     106FROM temp_course_id;
     107
     108INSERT INTO course_translate_what_will_be_learned (course_translate_id, what_will_be_learned)
     109SELECT id, 'Advanced sales techniques'
     110FROM temp_course_translate_id
     111WHERE language = 'en';
     112
     113INSERT INTO course_translate_what_will_be_learned (course_translate_id, what_will_be_learned)
     114SELECT id, 'How to successfully close deals'
     115FROM temp_course_translate_id
     116WHERE language = 'en';
     117
     118INSERT INTO course_translate_what_will_be_learned (course_translate_id, what_will_be_learned)
     119SELECT id, 'Напредни техники на продажба'
     120FROM temp_course_translate_id
     121WHERE language = 'mk';
     122
     123INSERT INTO course_translate_what_will_be_learned (course_translate_id, what_will_be_learned)
     124SELECT id, 'Како до успешно затворање на продажби'
     125FROM temp_course_translate_id
     126WHERE language = 'mk';
     127
     128COMMIT;
     129}}}
     130
     131== Pooling ==