اتصال به دیتابیس MariaDB در برنامه‌های NextJS


روش‌ها و کتابخانه‌های مختلفی برای اتصال به MariaDB در NextJS وجود دارد. یکی از این راه‌ها، استفاده از پکیج mariadb است که در ابتدا، با اجرای دستور زیر، باید آن را نصب کنید:

کپی
npm install mariadb

سپس، کافیست تا در فایل env.production. متغیرهای محیطی مربوط به دیتابیس خود را قرار دهید؛ به عنوان مثال:

کپی
DB_HOST=bromo.liara.cloud
DB_PORT=32703
DB_USER=root
DB_PASS=5T7kBqMMGLQYDGAkVdAtvd3L
DB_NAME=upbeat_rosalind

در ادامه، بایستی در مسیر lib (یا اگر که از دایرکتوری src استفاده می‌کنید؛ در مسیر src/lib)، یک فایل به نام mariadb.js ایجاد کنید و قطعه کد زیر را در آن، قرار دهید:

کپی
import mariadb from 'mariadb';

const pool = mariadb.createPool({
  host: process.env.DB_HOST,
  port: process.env.DB_PORT,
  user: process.env.DB_USER,
  password: process.env.DB_PASS,
  database: process.env.DB_NAME,
  connectionLimit: 5
});

export async function connectToMariaDB() {
  const connection = await pool.getConnection();
  return connection;
}

سپس، بایستی در مسیر pages/api (یا اگر که از دایرکتوری src استفاده می‌کنید؛ در مسیر src/pages/api)، یک فایل به نام mariadb.js بسازید و قطعه کد زیر را در آن، قرار دهید:

کپی
import { connectToMariaDB } from '@/lib/mariadb';

export default async function handler(req, res) {
  const connection = await connectToMariaDB();
  connection.release();

  res.status(200).json({ message: 'Connected to MariaDB successfully' });
}

تمامی کارها انجام شده است و شما می‌توانید با استفاده از قطعه کد مثال زیر در فایل pages/index.js (یا src/pages/index.js) از دیتابیس خود، استفاده کنید:

کپی
import { useEffect, useState } from 'react';

export default function Home() {
  const [data, setData] = useState(null);
  const [error, setError] = useState(null);

  useEffect(() => {
    async function fetchData() {
      try {
        const res = await fetch('/api/mariadb');
        const result = await res.json();
        setData(result);
      } catch (err) {
        setError(err);
      }
    }

    fetchData();
  }, []);

  return (
    <div>
      <h1>Database Connection Test</h1>
      {error ? (
        <p>Error: {error.message}</p>
      ) : data ? (
        <pre>{JSON.stringify(data, null, 2)}</pre>
      ) : (
        <p>Loading...</p>
      )}
    </div>
  );
}

در نظر داشته باشید که می‌توانید قطعه کدهای فوق را با توجه به نیاز خود، تغییر دهید.

استفاده از Connection Pooling

مفهوم Connection pooling به معنای استفاده از یک مجموعه اتصالات از پیش ساخته شده برای اتصال به پایگاه داده است. این تکنیک باعث می‌شود به جای ایجاد و بستن مکرر اتصالات، از اتصالات موجود در مجموعه استفاده شود که کارایی را افزایش می‌دهد.

در پکیج mariadb این قابلیت به صورت خودکار تعبیه شده است و شما می‌توانید در فایل lib/mariadb.js (یا src/lib/mariadb.js) حین اتصال به دیتابیس پارامتر زیر را بر اساس نیاز خود، مقدار دهی کنید:

کپی
const pool = mariadb.createPool({
  // other codes ...
  connectionLimit: 5  // amount of connections in a same time
});