把数据库中有关枚举项值的数字字符串转换成文字字符串

简介: 原文:把数据库中有关枚举项值的数字字符串转换成文字字符串  标题可能无法表达我的本意。比如,有这样一个枚举:   public enum MyChoice { MyFirstChoice = 0, MySecondChoice =1, MyThirdChoice = 2 }   数据库中,某表某字段保存值为"0,1,2",在显示的时候,我们希望是"第一个选择,第二个选择,第三个选择"。
原文: 把数据库中有关枚举项值的数字字符串转换成文字字符串

 

标题可能无法表达我的本意。比如,有这样一个枚举:

 

 
    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();
        }
目录
相关文章
|
3月前
|
关系型数据库 MySQL 数据库
MySQL数据库-截取字符串
MySQL数据库-截取字符串
26 0
|
3月前
|
关系型数据库 MySQL 数据库
MySQL数据库-字符串位数不够前面补0
MySQL数据库-字符串位数不够前面补0
22 0
|
2月前
|
关系型数据库 MySQL 数据库
数据库 -- 基础操作(一)文字版
数据库 -- 基础操作(一)文字版
16 0
|
2月前
|
数据库
数据库 -- 基础操作(二)文字版
数据库 -- 基础操作(二)文字版
10 0
|
4月前
|
前端开发 Java API
Java【代码分享 05】实现字符串转数据库的inStr使用JDK8 stream.collect(Collectors.joining(delimiter, prefix, suffix)) 实现
Java【代码分享 05】实现字符串转数据库的inStr使用JDK8 stream.collect(Collectors.joining(delimiter, prefix, suffix)) 实现
28 0
|
9月前
|
SQL 关系型数据库 MySQL
php替换mysql数据库中逗号组成的字符串的解决方案
php替换mysql数据库中逗号组成的字符串的解决方案
57 0
|
10月前
|
安全 数据库连接 数据库
sscms迁移服务器,修改数据库连接字符串
sscms迁移服务器,修改数据库连接字符串,siteserver
185 0
sscms迁移服务器,修改数据库连接字符串
|
存储 算法 数据库
CMU 15-445 数据库课程第五课文字版 - 缓冲池(上)
CMU 15-445 数据库课程第五课文字版 - 缓冲池(上)
CMU 15-445 数据库课程第五课文字版 - 缓冲池(上)
|
JSON fastjson 数据库
解析JSON字符串并添加到数据库中(超简单)
解析JSON字符串并添加到数据库中(超简单)
284 6
解析JSON字符串并添加到数据库中(超简单)