데이터베이스 조회 테이블에서 동적으로 열거형 생성
데이터베이스 조회 테이블에 저장된 값을 기반으로 열거형을 자동으로 생성하고 코드를 수동으로 수정하지 않고도 열거형을 데이터베이스와 동기화 상태로 유지하는 방법은 무엇입니까? 이것은 일반적인 질문입니다.
코드 생성 솔루션
완전히 자동화할 수는 없지만 코드 생성을 통해 솔루션을 제공할 수 있습니다. 솔루션에서 "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" 파일을 생성합니다.
기타 참고사항
위 내용은 데이터베이스 조회 테이블에서 열거형을 어떻게 동적으로 생성할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!