Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yildizmy/import-data-using-apache-commons-csv
Spring Boot application for importing csv file into MySQL db using Apache Commons CSV
https://github.com/yildizmy/import-data-using-apache-commons-csv
apache-commons-csv csv java mysql spring-boot spring-data-jpa spring-mvc
Last synced: about 2 months ago
JSON representation
Spring Boot application for importing csv file into MySQL db using Apache Commons CSV
- Host: GitHub
- URL: https://github.com/yildizmy/import-data-using-apache-commons-csv
- Owner: yildizmy
- License: mit
- Created: 2022-07-10T15:03:36.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2024-07-15T09:30:41.000Z (6 months ago)
- Last Synced: 2024-07-15T11:24:08.916Z (6 months ago)
- Topics: apache-commons-csv, csv, java, mysql, spring-boot, spring-data-jpa, spring-mvc
- Language: Java
- Homepage:
- Size: 66.4 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Import data into MySQL using Apache Commons CSV
Project used for importing csv file into MySQL database using Apache Commons CSV.## Description
Spring Boot provides some properties with which we can add the exception message, exception class, or even a stack trace as part of the response payload:
```
server.error.include-message=always
server.error.include-binding-errors=always
server.error.include-stacktrace=on_param
server.error.include-exception=false
```Using these Spring Boot server properties in our `application.properties` we can alter the error response to some extent.
Note that we’ve set the property `include-stacktracee` to `on_trace_param` which means that only if we include the trace param in the URL (`?trace=true`), we’ll get a stack trace in the response payload:
We might want to keep the value of `include-stacktrace` flag to `never`, at least in production, as it might reveal the internal workings of our application.
## Getting Started
### Dependencies
* Spring Web
* Spring Boot
* Spring Data JPA
* Apache Commons CSV
* MySQL Database### Installing
* Run the following command in the project root for creating MySQL database in Docker
```
docker-compose up -d
```To set container name as mysql instead of the folder name where `docker-compose.yml` file is located, use the following command:
```
docker-compose -f docker-compose.yml -p "mysql" up
```* Database connection url:
```
jdbc:mysql://localhost:3306/employee-db
```### API Endpoints
All URIs are relative to *http://localhost:8080/api/v1*
Class | Method | HTTP request | Description
------------ |-----------------------------------------------------------|----------------------| -------------
*EmployeeController* | [**importFile**](http://localhost:8080/api/v1/employees/import) | **POST** /employees/import | Import list of employees file
*EmployeeController* | [**findByEmail**](http://localhost:8080/api/v1/employees/{email}) | **GET** /employees/{email} | Get employee by email
*EmployeeController* | [**findAll**](http://localhost:8080/api/v1/employees) | **GET** /employees | Get all employees
*EmployeeController* | [**deleteAll**](http://localhost:8080/api/v1/employees) | **DELETE** /employees | Delete all employees## Documentation
[Apache Commons CSV User Guide](https://commons.apache.org/proper/commons-csv/user-guide.html#Using_an_enum_to_define_a_header)
[Hibernate ORM 5.6.10.Final User Guide](https://docs.jboss.org/hibernate/orm/5.6/userguide/html_single/Hibernate_User_Guide.html#naturalid)
[Hibernate Natural Ids with @NaturalId](https://howtodoinjava.com/hibernate/hibernate-naturalid-example-tutorial/)
[The best way to map a @NaturalId business key with JPA and Hibernate](https://vladmihalcea.com/the-best-way-to-map-a-naturalid-business-key-with-jpa-and-hibernate/)
[How to Use Hibernate Natural IDs in Spring Boot](https://dzone.com/articles/how-to-use-hibernate-natural-ids-in-spring-boot)## Authors
Murat Yıldız## Version History
* 0.2
* Various bug fixes and optimizations
* See [commit change]() or See [release history]()
* 0.1
* Initial Release## License
...
## Acknowledgements
...