목차
답글 내용:
백엔드 개발 PHP 튜토리얼 mysql - Thinkphp의 RBAC 인증에서 'user-role' 테이블에 독립 테이블이 필요한 이유는 무엇입니까? ?

mysql - Thinkphp의 RBAC 인증에서 'user-role' 테이블에 독립 테이블이 필요한 이유는 무엇입니까? ?

Aug 18, 2016 am 09:15 AM
mysql php thinkphp 권한 권한 제어

5개의 표는 여기에서 참고하실 수 있습니다: http://www.lyblog.net/detail/...

실제로 테이블이 있습니다:
mysql - Thinkphp의 RBAC 인증에서 'user-role' 테이블에 독립 테이블이 필요한 이유는 무엇입니까? ?

사용자와 역할 사이에는 일대일 대응이 있습니다. 다른 테이블을 생성하는 대신 사용자 테이블에 역할 필드를 추가하는 것은 어떨까요?
이렇게 하면 어떤 이점이 있나요?

보충:
어떤 사람들은 사용자와 역할이 일대다 관계라고 하는데 왜 일대다로 설정해야 하는지 알고 싶습니다.
일대일 관계를 다루는 것이 더 쉽지 않나요?

답글 내용:

5개의 표는 여기에서 참고하실 수 있습니다: http://www.lyblog.net/detail/...

실제로 테이블이 있습니다:
mysql - Thinkphp의 RBAC 인증에서 'user-role' 테이블에 독립 테이블이 필요한 이유는 무엇입니까? ?

사용자와 역할 사이에는 일대일 대응이 있습니다. 다른 테이블을 생성하는 대신 사용자 테이블에 역할 필드를 추가하는 것은 어떨까요?
이렇게 하면 어떤 이점이 있나요?

보충:
어떤 사람들은 사용자와 역할이 일대다 관계라고 하는데 왜 일대다로 설정해야 하는지 알고 싶습니다.
일대일 관계를 다루는 것이 더 쉽지 않나요?

사용자가 여러 역할을 가질 수 있다고 알고 있습니다

이렇습니다.

한 사람이 여러 역할을 가질 수 있습니다
한 역할은 여러 사람이 사용할 수도 있습니다
다대다 관계에서는 일반적으로 매핑할 중간 테이블이 필요합니다.

redis 비관계형 데이터베이스를 사용하지 않는 경우

일대다가 아니라 다대다입니다.

프로젝트에 필요하지 않을 수도 있지만 프레임워크로서 더 넓은 요구 사항을 고려해야 합니다. 이러한 관점에서 다대다 테이블은 일대일 테이블로 사용될 수 있습니다. 많은 것에는 일대일이 포함됩니다. 그러나 일대일 디자인은 필연적으로 다대다의 요구를 충족하지 못합니다. 그러면 여기에는 별도의 관계 테이블이 있을 것입니다. 알죠?

사용자에게는 여러 역할이 있습니다.

사실 별도의 테이블을 만들지 않는 것도 가능합니다.

분리, 단일 책임 모델

ManytoMany 관계에는 중간 테이블이 필요합니다!

다대다 요구를 충족하기 위해
제가 이해한 것이 정확하지 않을 수 있습니다. 예를 들어, 사용자 1, 2, 3은 여러 역할 a, b, c가 있습니다. 각각 a와 b에 해당합니다. ,c 세 가지 역할은 문제가 되지 않습니다. 다른 사용자 4가 오면 그에게 필요한 역할은 우연히 역할 a와 b의 권한을 갖게 되므로 사용자 4는 직접 역할 a와 b에 속합니다. 사용자 4의 요구 사항을 충족하기 위해 새 역할 d를 만들 필요가 없습니다

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

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

CakePHP 프로젝트 구성

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

CakePHP 날짜 및 시간

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

CakePHP 파일 업로드

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

CakePHP 라우팅

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP 토론

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 Dec 09, 2024 am 11:42 AM

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법

See all articles