把数据库中有关枚举项值的数字字符串转换成文字字符串
数据库 字符串 数字 文字 枚举 转换成 有关
2023-09-11 14:16:51 时间
标题可能无法表达我的本意。比如,有这样一个枚举:
public enum MyChoice{MyFirstChoice = 0,MySecondChoice =1,MyThirdChoice = 2}
数据库中,某表某字段保存值为"0,1,2",在显示的时候,我们希望是"第一个选择,第二个选择,第三个选择"。如何做呢?
可以为枚举项上面标注自定义特性。先自定义一个特性如下:
public class EnumDisplayNameAttribute : Attribute{private string _displayName;public EnumDisplayNameAttribute(string displayName){_displayName = displayName;}public string DisplayName{get{return _displayName;}}}
然后,把自定义特性标注放到枚举项上去。
public enum MyChoice{[EnumDisplayName("我的第一个选择")]MyFirstChoice = 0,[EnumDisplayName("我的第二个选择")]MySecondChoice =1,[EnumDisplayName("我的第三个选择")]MyThirdChoice = 2}
现在,需要一个帮助方法,能读出枚举项上的自定义特性EnumDisplayName。
public class EnumExt{/// <summary>/// 获取枚举项的注释/// </summary>/// <param name="e">枚举项</param>/// <returns></returns>public static string GetEnumDescription(object e){//获取枚举项Type t = e.GetType();//获取枚举项的字段FieldInfo[] fis = t.GetFields();foreach (FieldInfo fi in fis){//如果当前字段名称不是当前枚举项if (fi.Name != e.ToString()){continue;//结束本次循环}//如果当前字段的包含自定义特性if (fi.IsDefined(typeof (EnumDisplayNameAttribute), true)){//获取自定义特性的属性值return (fi.GetCustomAttributes(typeof(EnumDisplayNameAttribute), true)[0] as EnumDisplayNameAttribute).DisplayName;}}return e.ToString();}public static List<SelectListItem> GetSelectList(Type enumType){List<SelectListItem> selectList = new List<SelectListItem>();//selectList.Add(new SelectListItem{Text = "--请选择--",Value = ""});foreach (object e in Enum.GetValues(enumType)){selectList.Add(new SelectListItem { Text = GetEnumDescription(e), Value = ((int)e).ToString() });}return selectList;}}
以上,
● GetEnumDescription方法根据枚举项获取其上的自定义特性EnumDisplayNameAttribute的DisplayName属性值。
● GetSelectList方法根据枚举的Type类型返回SelectListItem集合,通常在ASP.NET MVC中使用。
最后,就能实现本篇的需求:
static void Main(string[] args){string myChoiceInt = "0,1,2";string[] choiceArr = myChoiceInt.Split(',');string temp = string.Empty;foreach (string item in choiceArr){//转换成枚举的类型short enumValShort = short.Parse(item);temp = temp + EnumExt.GetEnumDescription((MyChoice)enumValShort) + ",";}Console.WriteLine(temp.Substring(0, temp.Length - 1));Console.ReadKey();}
相关文章
- ADO.NET连接字符串大全---各种数据库的连接字符串
- 在Entity Framework中重用现有的数据库连接字符串
- 数据库分表后,并发环境下,生成全局id生成的几种方式
- win10 mysql数据库中文乱码
- 大数据量高并发访问的数据库优化方法(一)
- 数据库同时更新问题
- Spark操作MySQL,Hive并写入MySQL数据库
- Sql Server 导入另一个数据库中的表数据
- 使用Visual Studio的动态连接库创建通用数据库连接对话框
- 数据库面试题【一、事务四大特性】
- 亿级数据量场景下,如何优化数据库分页查询方法?
- 快速迁移数据中心:华为云数据库SQL Server实践案例技术解析
- python使用插入带有%的字符串到mysql数据库
- 55 openEuler搭建Mariadb数据库服务器-配置环境
- PostgreSQL的学习心得和知识总结(九十四)|深入理解PostgreSQL数据库开源MPP扩展Citus DDL命令下发 的实现原理
- MySQL 数据库读写分离
- Oracle的学习心得和知识总结(四)|Oracle数据库表压缩技术详解