>백엔드 개발 >C++ >데이터베이스 조회 테이블에서 열거형을 어떻게 동적으로 생성할 수 있습니까?

데이터베이스 조회 테이블에서 열거형을 어떻게 동적으로 생성할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-12 06:50:42661검색

How Can Enums Be Dynamically Generated from a Database Lookup Table?

데이터베이스 조회 테이블에서 동적으로 열거형 생성

데이터베이스 조회 테이블에 저장된 값을 기반으로 열거형을 자동으로 생성하고 코드를 수동으로 수정하지 않고도 열거형을 데이터베이스와 동기화 상태로 유지하는 방법은 무엇입니까? 이것은 일반적인 질문입니다.

코드 생성 솔루션

완전히 자동화할 수는 없지만 코드 생성을 통해 솔루션을 제공할 수 있습니다. 솔루션에서 "EnumeratedTypes"라는 별도의 프로젝트를 생성하면 열거형을 자동으로 생성할 수 있습니다. 이 프로젝트는 데이터베이스에서 값을 검색하고, 해당 값에서 열거형을 구성하고, 이를 별도의 어셈블리에 저장하는 콘솔 애플리케이션 역할을 합니다.

이 코드 생성 프로젝트에서는 다음 코드를 사용하여 동적 열거형을 정의하고 채웁니다.

<code class="language-csharp">// 创建动态程序集
AssemblyName name = new AssemblyName("MyEnums");
AssemblyBuilder assemblyBuilder = currentDomain.DefineDynamicAssembly(name, AssemblyBuilderAccess.RunAndSave);

// 定义动态模块
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule(name.Name, name.Name + ".dll");

// 定义公共枚举
EnumBuilder myEnum = moduleBuilder.DefineEnum("EnumeratedTypes.MyEnum", TypeAttributes.Public, typeof(int));

// 从数据库检索数据
MyDataAdapter someAdapter = new MyDataAdapter();
MyDataSet.MyDataTable myData = myDataAdapter.GetMyData();

// 定义枚举文字
foreach (MyDataSet.MyDataRow row in myData.Rows)
{
    myEnum.DefineLiteral(row.Name, row.Key);
}

// 创建枚举并保存程序集
myEnum.CreateType();
assemblyBuilder.Save(name.Name + ".dll");</code>

솔루션의 다른 프로젝트에서는 생성된 이 어셈블리를 참조하여 동적 열거형에 액세스하고 IntelliSense 지원을 제공할 수 있습니다.

빌드 후 이벤트 자동화

열거의 자동 생성을 보장하기 위해 "EnumeratedTypes" 프로젝트는 빌드 후 이벤트를 추가할 수 있습니다. 이 이벤트는 빌드 프로세스 중에 실행되며 "MyEnums.dll" 파일을 생성합니다.

기타 참고사항

  • "MyEnums.dll"이 삭제된 경우 빌드 실패를 방지하려면 "EnumeratedTypes" 프로젝트가 먼저 빌드되도록 빌드 순서를 수정하세요.
  • 동적 코드 생성에 대한 자세한 내용은 MSDN 문서를 참조하세요.

위 내용은 데이터베이스 조회 테이블에서 열거형을 어떻게 동적으로 생성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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