DataHelper.cs 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Data;
  6. using NHibernate;
  7. using System.Collections;
  8. using System.Security.Cryptography;
  9. using FluentNHibernate.Cfg;
  10. using System.Reflection;
  11. namespace MixTraffic
  12. {
  13. public partial class DataHelper
  14. {
  15. public static bool OutputSQLString { get; set; }
  16. private string m_databaseAddress;
  17. private int m_databasePort;
  18. private static readonly string databaseName = "casun_map";
  19. private static readonly string databaseAccount = "casun";
  20. private static readonly string accountPassword = "casunagv";
  21. private ISessionFactory m_factory = null;
  22. private object obj = new object();
  23. private string _connectionString;
  24. public ISession session
  25. {
  26. get
  27. {
  28. if (m_factory == null)
  29. {
  30. lock (obj)
  31. {
  32. try
  33. {
  34. if (m_factory == null) m_factory = createSessionFactory();
  35. }
  36. catch { throw; }
  37. }
  38. }
  39. return m_factory.OpenSession();
  40. }
  41. }
  42. public void initialize(string dbAddress, int dbPort)
  43. {
  44. m_databaseAddress = dbAddress;
  45. m_databasePort = dbPort;
  46. try
  47. {
  48. if (m_factory != null) m_factory.Dispose();
  49. m_factory = createSessionFactory();
  50. }
  51. catch { throw; }
  52. }
  53. public void initialize(string path)
  54. {
  55. _connectionString = "Data Source =" + path;
  56. try
  57. {
  58. if (m_factory != null) m_factory.Dispose();
  59. m_factory = createSessionFactory();
  60. }
  61. catch { throw; }
  62. }
  63. public void initialize(string strDatabaseServer,
  64. int databasePort,
  65. string strDatabaseName,
  66. string strUserName,
  67. string strPassword)
  68. {
  69. //if (m_sessionFactory != null) return;
  70. try
  71. {
  72. string connectionString = string.Format("Server={0};Port={1};Database={2};Uid={3};Pwd={4};",
  73. strDatabaseServer, databasePort, strDatabaseName, strUserName, strPassword);
  74. FluentConfiguration config = Fluently.Configure()
  75. .Database(FluentNHibernate.Cfg.Db.MsSqlConfiguration.MsSql2008
  76. .ConnectionString(connectionString));
  77. Assembly curAssembly = Assembly.GetExecutingAssembly();
  78. NHibernate.Cfg.Configuration cfg = config.Mappings(m => m.FluentMappings.AddFromAssembly(curAssembly)).BuildConfiguration();
  79. m_factory = cfg.BuildSessionFactory();
  80. // m_mappingSet.buildMappings(cfg);
  81. }
  82. catch { throw; }
  83. }
  84. public void close()
  85. {
  86. if (m_factory != null) { m_factory.Close(); m_factory = null; }
  87. }
  88. private ISessionFactory createSessionFactory()
  89. {
  90. try
  91. {
  92. //NHibernate.Cfg.Configuration
  93. string connectionString =_connectionString;// string.Format("Server={0};Port={1};Database={2};Uid={3};Pwd={4};",
  94. //m_databaseAddress, m_databasePort, databaseName, databaseAccount, accountPassword);
  95. FluentConfiguration config = Fluently.Configure()
  96. .Database(FluentNHibernate.Cfg.Db.MsSqlConfiguration.MsSql2008
  97. .ConnectionString(connectionString));
  98. Assembly curAssembly = Assembly.GetExecutingAssembly();
  99. NHibernate.Cfg.Configuration cfg = config.Mappings(m => m.FluentMappings.AddFromAssembly(curAssembly))
  100. .ExposeConfiguration(f => f.SetInterceptor(new SqlStatementInterceptor()))
  101. .BuildConfiguration();
  102. return cfg.BuildSessionFactory();
  103. }
  104. catch { throw; }
  105. }
  106. public static string md5Encrypt(string strSource)
  107. {
  108. byte[] buffer = Encoding.UTF8.GetBytes(strSource);
  109. MD5 md5 = new MD5CryptoServiceProvider();
  110. byte[] output = md5.ComputeHash(buffer);
  111. return Convert.ToBase64String(output);
  112. }
  113. /*
  114. public static string GetLockerAddress(int locationID, ISession session)
  115. {
  116. try
  117. {
  118. IDbCommand cmd = session.Connection.CreateCommand();
  119. cmd.CommandText = "GetLockerAddress";
  120. cmd.CommandType = CommandType.StoredProcedure;
  121. IDbDataParameter p1 = cmd.CreateParameter();
  122. p1.ParameterName = "locationID";
  123. p1.Direction = ParameterDirection.Input;
  124. p1.Value = locationID;
  125. cmd.Parameters.Add(p1);
  126. IDbDataParameter p2 = cmd.CreateParameter();
  127. p2.ParameterName = "address";
  128. p2.Direction = ParameterDirection.Output;
  129. cmd.Parameters.Add(p2);
  130. cmd.ExecuteNonQuery();
  131. return p2.Value.ToString();
  132. }
  133. catch { throw; }
  134. }
  135. */
  136. public class SqlStatementInterceptor : EmptyInterceptor
  137. {
  138. public override NHibernate.SqlCommand.SqlString OnPrepareStatement(NHibernate.SqlCommand.SqlString sql)
  139. {
  140. //#if DEBUG
  141. try
  142. {
  143. //File.AppendAllText("c:\\log.txt", string.Format("{0}\n", sql.ToString()));
  144. }
  145. catch
  146. {
  147. }
  148. //#endif
  149. return sql;
  150. }
  151. }
  152. /// <summary>
  153. /// 执行存储过程
  154. /// </summary>
  155. /// <param name="session"></param>
  156. /// <param name="procedureName"></param>
  157. /// <param name="inParams"></param>
  158. /// <param name="outParams"></param>
  159. public static void executeStoreProcedure(ISession session, string procedureName, Hashtable inParams, Hashtable outParams)
  160. {
  161. try
  162. {
  163. IDbCommand cmd = session.Connection.CreateCommand();
  164. cmd.CommandText = procedureName;
  165. cmd.CommandType = CommandType.StoredProcedure;
  166. //填充传入参数
  167. if (inParams != null)
  168. {
  169. foreach (string key in inParams.Keys)
  170. {
  171. IDbDataParameter p = cmd.CreateParameter();
  172. p.Direction = ParameterDirection.Input;
  173. p.ParameterName = key;
  174. p.Value = inParams[key];
  175. cmd.Parameters.Add(p);
  176. }
  177. }
  178. //填充传出参数
  179. if (outParams != null)
  180. {
  181. foreach (string key in outParams.Keys)
  182. {
  183. IDbDataParameter p = cmd.CreateParameter();
  184. p.Direction = ParameterDirection.Output;
  185. p.ParameterName = key;
  186. p.Value = inParams[key];
  187. cmd.Parameters.Add(p);
  188. }
  189. }
  190. cmd.ExecuteNonQuery();
  191. }
  192. catch { throw; }
  193. }
  194. }
  195. }