1
0
mirror of https://github.com/actix/examples synced 2025-01-22 14:05:55 +01:00
2023-07-17 22:13:50 +01:00
..
2023-07-17 18:56:41 +01:00
2023-07-17 17:55:17 +01:00
2023-07-17 22:13:50 +01:00
2023-07-17 20:59:04 +01:00
2023-07-17 20:59:04 +01:00

MySQL

This RESTful Actix Web API examples illustrates how to connect to MySQL database using a MySQL client library implemented in Rust; e.g., MySQL database driver.

Below APIs are supported:

  • Add Bank
  • Add Branch
  • Add Teller
  • Add Customer
  • Get Bank
  • Get Branch
  • Get Teller
  • Get Customer

The RESTful Actix Web API has below listed dependencies:

  • Actix Web web framework for Rust
  • Serde for serializing and deserializing Rust data structures
  • MySQL Server MySQL database server
  • MySQL MySQL database driver

Instructions

NOTE:

You may need to ensure that you are running the commands with the correct MySQL user/password.

  1. Access MySQL Server:

    Log in to the MySQL Server using a user account that has the CREATE DATABASE privilege.

  2. Create database:

    CREATE DATABASE my_bank;
    
  3. Create tables in the database:

    The sql directory contains below listed ".sql" files:

    • bankdetails.sql
    • branch_details.sql
    • teller_details.sql
    • customer_details.sql

    Copy the contents of each of the ".sql" and execute them separately on MySQL Server. This will create four tables in the database.

  4. Create .env file:

    SERVER_ADDR=127.0.0.1:8080
    MYSQL_USER=XXX
    MYSQL_PASSWORD=XXX
    MYSQL_HOST=127.0.0.1
    MYSQL_PORT=3306
    MYSQL_DBNAME=my_bank
    

    Update "MYSQL_USER" and "MYSQL_PASSWORD" values with the correct MySQL user/password. If your password contains dollar sign "$", then remember to escape it eg "123$abc" will need to be changed to "123\$abc"

  5. Run the server:

    cargo run
    
  6. Using a different terminal send an HTTP GET/POST requests to the running server:

    The apis directory contains below listed API's files:

    • bank.txt
    • branch.txt
    • teller.txt
    • customer.txt

    Copy the curl request on each of the ".txt" and execute them on separate terminals. Each ".txt" contains curl request and expected JSON response data.