檢測空值,以及會不會出現mapping類型不一致的問題

來源:互聯網
上載者:User

標籤:iter   oda   code   tor   convert   public   registry   for   context   

   /// <summary>        /// 檢測空值,以及會不會出現mapping類型不一致的問題        /// </summary>        /// <typeparam name="T"></typeparam>        /// <param name="nullsb1"></param>        /// <param name="errorsb"></param>        public static void CheckHibernateMappingType<T>(out StringBuilder nullsb1,out StringBuilder errorsb) where T:Framework.Domain.Entity,new()        {            nullsb1 = new StringBuilder();            errorsb = new StringBuilder();            var ctx = Spring.Context.Support.ContextRegistry.GetContext();            var Dao = GetDao();            var mapping = ((Spring.Data.NHibernate.LocalSessionFactoryObject)ctx.GetObject("&SessionFactory")).Configuration.GetClassMapping(typeof(T));            var pmap = mapping.PropertyIterator;            var tableName1 = mapping.Table.Name;            var table = Dao.ExecuteDataSet(new QueryInfo() { CustomSQL = "select * from " + tableName1 }).Tables[0];            Hashtable columnsType = new Hashtable();            foreach (DataColumn col in table.Columns)            {                columnsType.Add(col.ColumnName, col.DataType.Name);            }            string primaryKey = ((NHibernate.Mapping.Column)(mapping.Key.ColumnIterator.FirstOrDefault())).Name;            StringBuilder sb = new StringBuilder();            StringBuilder sb1 = new StringBuilder();            foreach (DataRow dr in table.Rows)            {                foreach (var item in pmap)                {                    NHibernate.Mapping.Column c = (NHibernate.Mapping.Column)item.ColumnIterator.FirstOrDefault();                    //1對多的屬性如children沒有對應的列                    if (c != null)                    {                        string columnTypeName = columnsType[c.Name].ToString();                        try                        {                            if (dr[c.Name] is DBNull)                            {                                nullsb1.Append("主鍵" + dr[primaryKey].ToString() + "列" + c.Name + "約定類型為:" + columnTypeName + "值為:NULL\r\n");                                continue;                            }                            switch (columnTypeName)                            {                                case "String":                                    break;                                case "Int16":                                    Convert.ToInt16(dr[c.Name]);                                    break;                                case "Int32":                                    Convert.ToInt32(dr[c.Name]);                                    break;                                case "Int64":                                    Convert.ToInt64(dr[c.Name]);                                    break;                                case "Decimal":                                    Convert.ToDecimal(dr[c.Name]);                                    break;                                case "DateTime":                                    Convert.ToDateTime(dr[c.Name]);                                    break;                                case "Boolean":                                case "bool":                                    Convert.ToBoolean(dr[c.Name]);                                    break;                                default:                                    break;                            }                        }                        catch (Exception ex)                        {                            sb.Append("主鍵" + dr[primaryKey].ToString() + "列" + c.Name + "約定類型為:" + columnTypeName + "值為:" + dr[c.Name] + "??類型轉換異常\r\n");                        }                    }                }            }        }

 

檢測空值,以及會不會出現mapping類型不一致的問題

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.