{"id":26746755,"url":"https://github.com/skyrocketstan/learning_netology_jdbc","last_synced_at":"2025-10-11T18:16:05.153Z","repository":{"id":107395933,"uuid":"579116207","full_name":"SkyrocketStan/Learning_Netology_jdbc","owner":"SkyrocketStan","description":"Домашнее задание к занятию 8.3: JDBC API, JdbcTemplate, NamedParametersJdbcTemplate","archived":false,"fork":false,"pushed_at":"2022-12-21T11:54:04.000Z","size":13,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2023-08-30T22:46:53.601Z","etag":null,"topics":["homework","java","java-learning","jdbc","netology","spring-boot","spring-learning","sql"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":false,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/SkyrocketStan.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null}},"created_at":"2022-12-16T17:45:32.000Z","updated_at":"2023-08-30T22:46:53.601Z","dependencies_parsed_at":"2023-05-23T22:15:28.742Z","dependency_job_id":null,"html_url":"https://github.com/SkyrocketStan/Learning_Netology_jdbc","commit_stats":null,"previous_names":["bytevirtuoso/learning_netology_jdbc","skyrocketstan/learning_netology_jdbc"],"tags_count":0,"template":null,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SkyrocketStan%2FLearning_Netology_jdbc","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SkyrocketStan%2FLearning_Netology_jdbc/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SkyrocketStan%2FLearning_Netology_jdbc/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/SkyrocketStan%2FLearning_Netology_jdbc/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/SkyrocketStan","download_url":"https://codeload.github.com/SkyrocketStan/Learning_Netology_jdbc/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245999619,"owners_count":20707572,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["homework","java","java-learning","jdbc","netology","spring-boot","spring-learning","sql"],"created_at":"2025-03-28T09:15:27.328Z","updated_at":"2025-10-11T18:16:00.116Z","avatar_url":"https://github.com/SkyrocketStan.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Домашнее задание к занятию 8.3: JDBC API, JdbcTemplate, NamedParametersJdbcTemplate\n\n## Задача DAO слой\n\n### Описание\nПопрактикуемся в работе с Spring JDBC, попутно закрепляя уже пройденные темы. Вам надо написать приложение для работы с БД, использую скрипты, который вы написали во [втором задании](https://github.com/ProsperousRF/Learning_Netology_sql-agg)\n\n1. Создайте spring boot приложение, с зависимостями на два starter'а - `spring-boot-starter-jdbc` и `spring-boot-starter-web`\n\n2. Перенесите скрипт создания таблицы в файл `schema.sql`, чтобы spring boot автоматически создавал таблицу.\n\n2. Перенесите скрипт запроса из второго задания в папку `resources`. Перепишите скрипт так, чтобы она возвращал `product_name` для именованного параметра `name`(а не только для `alexey`), который вы будете передавать в методы выполнения скрипта `NamedParameterJdbcTemplate` вместе со скриптом запроса.\n\n3. Напишите репозиторий для работы с БД. Для этого:\n - создайте класс и пометьте его аннотацией Repository, либо создайте бин репозитория в Java config классе\n - добавьте в поле класса String, которое содержит ваше содержание вашего скрипта. Само содержание вы можете считать с помощью кода ниже. Вам надо будет передать в метод `read` название вашего скрипта, который лежит в папке `resources`. Например так: `read(myScript.sql)`.\n - создайте метод `getProductName(String name)`, который будет принимать имя и возвращать название продукта из базы данных.\n```java\nprivate static String read(String scriptFileName) {\n        try (InputStream is = new ClassPathResource(scriptFileName).getInputStream();\n             BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(is))) {\n            return bufferedReader.lines().collect(Collectors.joining(\"\\n\"));\n        } catch (IOException e) {\n            throw new RuntimeException(e);\n        }\n    }\n``` \n\n4. Напишите контроллер, с методом-обработчиком GET-метода запроса с маппингом на endpoint `/products/fetch-product`. В query params запроса будет приходить строковый параметр `name`, который вам надо будет передавать дальше в репозиторий. То есть, ваш метод должен уметь обрабатывать запрос вида `localhost:8080/products/fetch-product?name=Ivan`.\nКонтроллер должен будет возвращать название продукта, который он получит от репозитория.\n\n5. Написанные код выложите в отдельный репозиторий на гитхабе и прикрепите ссылку на него в домашнем задании.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fskyrocketstan%2Flearning_netology_jdbc","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fskyrocketstan%2Flearning_netology_jdbc","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fskyrocketstan%2Flearning_netology_jdbc/lists"}