>  기사  >  웹 프론트엔드  >  React Query 데이터베이스 플러그인: 메시지 큐와의 통합 실습

React Query 데이터베이스 플러그인: 메시지 큐와의 통합 실습

王林
王林원래의
2023-09-29 11:05:111449검색

React Query 数据库插件:与消息队列的整合实践

React 쿼리 데이터베이스 플러그인: Message Queue와의 통합 실습

소개:
현대 웹 개발에서 프런트 엔드와 데이터베이스 간의 상호 작용은 매우 일반적인 요구 사항입니다. 강력한 상태 관리 라이브러리인 React Query는 편리한 데이터 쿼리 및 업데이트 메커니즘을 제공할 뿐만 아니라 다양한 백엔드 기술과 데이터 저장 솔루션을 쉽게 통합할 수 있는 플러그인 시스템을 제공합니다. 이 기사에서는 React Query 데이터베이스 플러그인을 사용하고 메시지 대기열과 결합하여 보다 효율적인 데이터 상호 작용을 달성하는 방법을 소개합니다.

1. React Query 데이터베이스 플러그인 소개
React Query 데이터베이스 플러그인은 React Query의 기능을 확장하고 데이터 추가, 삭제, 수정 및 쿼리 작업을 위한 보다 편리한 방법을 제공하는 오픈 소스 코드 라이브러리입니다. . 플러그인은 MySQL, PostgreSQL, MongoDB 등과 같은 다양한 데이터베이스를 지원하며 다른 데이터베이스에 맞게 사용자 정의할 수도 있습니다.

2. React Query 데이터베이스 플러그인 설치 및 구성

  1. Installation
    먼저 프로젝트에 React Query와 데이터베이스 플러그인을 설치해야 합니다. 설치는 npm 또는 Yarn을 통해 완료할 수 있습니다. 다음은 npm을 예로 들어 설명합니다.

    npm install react-query
    npm install react-query-db-plugin
  2. Configuration
    React Query 구성 파일에서 데이터베이스 플러그인을 소개하고 등록합니다.

    import { QueryClient, QueryClientProvider } from 'react-query';
    import { createDBPlugin } from 'react-query-db-plugin';
    
    //创建QueryClient
    const queryClient = new QueryClient();
    
    //创建并注册数据库插件
    const dbPlugin = createDBPlugin({
      //数据库配置信息
      host: 'localhost',
      port: 3306,
      username: 'root',
      password: 'password',
      database: 'my-database',
    });
    queryClient.registerPlugin(dbPlugin);
    
    //将QueryClientProvider包裹在根组件外部
    ReactDOM.render(
      <QueryClientProvider client={queryClient}>
     <App />
      </QueryClientProvider>,
      document.getElementById('root')
    );

3. 다음을 사용합니다. 데이터 상호 작용을 구현하는 React Query 데이터베이스 플러그인
MySQL 데이터베이스를 예로 들어 React Query 데이터베이스 플러그인을 사용하여 데이터 추가, 삭제, 수정 및 쿼리 작업을 구현하는 방법을 소개하겠습니다.

  1. 데이터 쿼리
    React 구성 요소에서는 useQuery 메서드를 사용하여 데이터를 쿼리할 수 있습니다. 예를 들어, 데이터베이스에서 사용자 목록을 가져오려고 합니다. useQuery方法来进行数据的查询操作。例如,我们希望从数据库中获取用户列表:

    import { useQuery } from 'react-query';
    import { db } from 'react-query-db-plugin';
    
    const UserList = () => {
      const { data, isLoading } = useQuery('userList', () => {
     return db.query('SELECT * FROM users');
      });
    
      if (isLoading) {
     return <div>Loading...</div>;
      }
    
      return (
     <ul>
       {data.map(user => (
         <li key={user.id}>{user.name}</li>
       ))}
     </ul>
      );
    };
  2. 创建数据
    要创建新的数据,可以使用useMutation

    import { useMutation } from 'react-query';
    import { db } from 'react-query-db-plugin';
    
    const AddUserForm = () => {
      const mutation = useMutation(values => {
     return db.query('INSERT INTO users SET ?', values);
      });
    
      const handleSubmit = e => {
     e.preventDefault();
     mutation.mutate({
       name: e.target.elements.name.value,
       age: e.target.elements.age.value,
     });
      };
    
      return (
     <form onSubmit={handleSubmit}>
       <input name="name" type="text" placeholder="Name" />
       <input name="age" type="number" placeholder="Age" />
       <button type="submit" disabled={mutation.isLoading}>
         {mutation.isLoading ? 'Loading...' : 'Add'}
       </button>
     </form>
      );
    };

  3. Create data
  4. 새 데이터를 생성하려면 useMutation 메서드를 사용할 수 있습니다. 예를 들어, 새 사용자를 추가하는 양식을 만듭니다.
const mutation = useMutation(values => {
  return db.query('INSERT INTO users SET ?', values)
 .then(() => {
   //发布事件
   queue.publish('userAdded', values);
 });
});


데이터 업데이트 및 데이터 삭제 작업은 데이터 생성과 유사하며 이를 수행하려면 다른 SQL 문만 사용해야 합니다.

  1. 4. 메시지 큐를 이용한 통합 연습

    실제 개발에서는 비동기 데이터 처리를 위해 메시지 큐를 사용하는 경우가 많습니다. React Query 데이터베이스 플러그인과 메시지 큐의 통합 실행은 다음과 같은 방법으로 달성할 수 있습니다:

  2. 데이터 변경 이벤트 게시

    데이터 추가, 삭제, 수정 및 쿼리 작업이 완료된 후 데이터 변경 이벤트가 발생할 수 있습니다. 메시지 큐를 통해 전송됩니다. 예를 들어 위의 데이터 생성 예에서는 데이터가 삽입된 후 이벤트를 게시할 수 있습니다.

    import { useQuery, useQueryClient } from 'react-query';
    import { db } from 'react-query-db-plugin';
    import { queue } from 'react-query-message-queue';
    
    const UserList = () => {
      const queryClient = useQueryClient();
    
      const { data, isLoading } = useQuery('userList', () => {
     return db.query('SELECT * FROM users');
      });
    
      //订阅事件
      useEffect(() => {
     const subscription = queue.subscribe('userAdded', payload => {
       queryClient.setQueryData('userList', oldData => {
         //在现有的用户列表数据之后添加新用户
         return [...oldData, payload];
       });
     });
    
     return () => {
       subscription.unsubscribe();
     };
      }, []);
    
      if (isLoading) {
     return <div>Loading...</div>;
      }
    
      return (
     <ul>
       {data.map(user => (
         <li key={user.id}>{user.name}</li>
       ))}
     </ul>
      );
    };

데이터 변경 이벤트 구독

인터페이스나 기타 비동기 작업을 업데이트해야 하는 경우 해당 데이터 변경 이벤트를 처리하고 그에 따라 처리를 수행합니다. 예를 들어, 사용자 목록이 변경되면 인터페이스를 업데이트하려고 합니다.
rrreee

🎜🎜 5. 요약🎜React Query 데이터베이스 플러그인을 사용하면 데이터베이스 작업을 쉽게 수행하고 메시지 대기열과 결합하여 보다 효율적인 데이터를 얻을 수 있습니다. 상호 작용. 이 글에서는 React Query 데이터베이스 플러그인을 설치 및 구성하는 방법과 플러그인을 사용하여 데이터를 쿼리, 생성, 업데이트 및 삭제하는 방법을 소개합니다. 또한, 비동기 데이터 처리를 달성하기 위해 React Query를 메시지 대기열과 통합하는 방법도 소개했습니다. 이 글이 여러분이 React Query 데이터베이스 플러그인을 더 깊이 이해하고 적용하는 데 도움이 되기를 바랍니다. 🎜

위 내용은 React Query 데이터베이스 플러그인: 메시지 큐와의 통합 실습의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.