프로젝트

일반

사용자정보

통계
| 브랜치(Branch): | 개정판:

hytos / DTI_PID / POSCO_Report / DB.cs @ d3ffdbec

이력 | 보기 | 이력해설 | 다운로드 (11.9 KB)

1
using System;
2
using System.Collections.Generic;
3
using System.Linq;
4
using System.Text;
5
using System.Threading.Tasks;
6
using System.Data.SQLite;
7
using System.Globalization;
8
using System.Data;
9
using System.Windows.Forms;
10
using System.IO;
11

    
12
namespace POSCO_Report
13
{
14
	
15

    
16
	public static class DB
17
	{
18
		const string HMB_From_To = "HMB_From_To";
19
		const string HMB_LIST = "HMB_LIST";
20
		const string HMB_VALUE = "HMB_VALUE";
21
		const string Stream_No = "Stream_No";
22
		const string Components = "Components";
23
		const string Attributes = "Attributes";
24
		const string Symbol = "Symbol";
25
		const string SymbolType = "SymbolType";
26
		const string SymbolAttribute = "SymbolAttribute";
27

    
28
		public static bool CheckConnection()
29
		{
30
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
31
			bool result = false;
32
			try
33
			{
34
				if (projectInformation.DBType.Equals(DBType.SQLite))
35
				{
36
					using (SQLiteConnection connection = new SQLiteConnection(projectInformation.ConnString, true))
37
					{
38
						connection.Open();
39
						if (connection.State.Equals(ConnectionState.Open))
40
						{
41
                            using (SQLiteCommand cmd = connection.CreateCommand())
42
                            {
43
                                cmd.CommandText = "SELECT NAME FROM sqlite_master WHERE type='table'";
44
                                using (SQLiteDataReader dr = cmd.ExecuteReader())
45
                                using (DataTable dt = new DataTable())
46
                                {
47
                                    dt.Load(dr);
48

    
49
                                    if (dt.Select(string.Format("NAME = '{0}'", HMB_From_To)).Length.Equals(1) &&
50
										dt.Select(string.Format("NAME = '{0}'", HMB_LIST)).Length.Equals(1) &&
51
										dt.Select(string.Format("NAME = '{0}'", HMB_VALUE)).Length.Equals(1) &&
52
										dt.Select(string.Format("NAME = '{0}'", Stream_No)).Length.Equals(1) &&
53
										dt.Select(string.Format("NAME = '{0}'", Components)).Length.Equals(1) &&
54
										dt.Select(string.Format("NAME = '{0}'", Attributes)).Length.Equals(1))
55
                                    {
56
										result = true;
57
									}
58
                                }
59
                            }
60
                            
61
						}
62
						connection.Close();
63
					}
64
				}
65
				else if (projectInformation.DBType.Equals(DBType.MSSQL))
66
				{
67
					throw new Exception("mssql");
68
				}
69
			}
70
			catch (Exception ex)
71
			{
72
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
73
			}
74
			
75
			return result;
76
		}
77
		public static DataTable GetSymbolTable()
78
		{
79
			DataTable dt = new DataTable();
80
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
81
			try
82
			{
83
				if (projectInformation.DBType.Equals(DBType.SQLite))
84
				{
85
					using (SQLiteConnection connection = new SQLiteConnection(projectInformation.ConnString, true))
86
					{
87
						connection.Open();
88
						if (connection.State.Equals(ConnectionState.Open))
89
						{
90
							using (SQLiteCommand cmd = connection.CreateCommand())
91
							{
92
								cmd.CommandText = string.Format("SELECT s.UID, s.Name, st.Type, s.BaseSymbol FROM {0} s LEFT JOIN {1} st on s.SymbolType_UID = st.UID WHERE s.BaseSymbol IS NOT NULL", Symbol, SymbolType);
93
								using (SQLiteDataReader dr = cmd.ExecuteReader())
94
									dt.Load(dr);
95
							}
96

    
97
						}
98
						connection.Close();
99
					}
100
				}
101
				else if (projectInformation.DBType.Equals(DBType.MSSQL))
102
				{
103
					throw new Exception("mssql");
104
				}
105
			}
106
			catch (Exception ex)
107
			{
108
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
109
			}
110

    
111
            dt.DefaultView.Sort = "Name";
112
            dt = dt.DefaultView.ToTable();
113

    
114
            return dt;
115
		}
116
		public static DataTable GetSymbolAttributeTable()
117
		{
118
			DataTable dt = new DataTable();
119
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
120
			try
121
			{
122
				if (projectInformation.DBType.Equals(DBType.SQLite))
123
				{
124
					using (SQLiteConnection connection = new SQLiteConnection(projectInformation.ConnString, true))
125
					{
126
						connection.Open();
127
						if (connection.State.Equals(ConnectionState.Open))
128
						{
129
							using (SQLiteCommand cmd = connection.CreateCommand())
130
							{
131
								cmd.CommandText = string.Format("SELECT DISTINCT Attribute FROM {0}", SymbolAttribute);
132
								using (SQLiteDataReader dr = cmd.ExecuteReader())
133
									dt.Load(dr);
134
							}
135
						}
136
						connection.Close();
137
					}
138
				}
139
				else if (projectInformation.DBType.Equals(DBType.MSSQL))
140
				{
141
					throw new Exception("mssql");
142
				}
143
			}
144
			catch (Exception ex)
145
			{
146
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
147
			}
148

    
149
            dt.DefaultView.Sort = "Attribute";
150
            dt = dt.DefaultView.ToTable();
151

    
152
            return dt;
153
		}
154
		public static DataTable GetHMBCaseDataTable()
155
		{
156
			DataTable dt = new DataTable();
157
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
158
			try
159
			{
160
				if (projectInformation.DBType.Equals(DBType.SQLite))
161
				{
162
					using (SQLiteConnection connection = new SQLiteConnection(projectInformation.ConnString, true))
163
					{
164
						connection.Open();
165
						if (connection.State.Equals(ConnectionState.Open))
166
						{
167
							using (SQLiteCommand cmd = connection.CreateCommand())
168
							{
169
								cmd.CommandText = string.Format(@"
170
								SELECT hv.UID, hv.Value, hv.[Case], hv.HMB_LIST_UID, hl.Name, hl.Unit, hl.Type, st.Stream_No
171
								FROM {0} hv 
172
								LEFT JOIN {1} hl 
173
								ON hv.HMB_LIST_UID = hl.UID
174
								LEFT JOIN {2} st
175
								ON hv.Stream_No_UID = st.UID", HMB_VALUE, HMB_LIST, Stream_No);
176
								using (SQLiteDataReader dr = cmd.ExecuteReader())
177
									dt.Load(dr);
178
							}
179

    
180
						}
181
						connection.Close();
182
					}
183
				}
184
				else if (projectInformation.DBType.Equals(DBType.MSSQL))
185
				{
186
					throw new Exception("mssql");
187
				}
188
			}
189
			catch (Exception ex)
190
			{
191
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
192
			}
193
			return dt;
194
		}
195
		public static DataTable GetHMBListDataTable()
196
		{
197
			DataTable dt = new DataTable();
198
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
199
			try
200
			{
201
				if (projectInformation.DBType.Equals(DBType.SQLite))
202
				{
203
					using (SQLiteConnection connection = new SQLiteConnection(projectInformation.ConnString, true))
204
					{
205
						connection.Open();
206
						if (connection.State.Equals(ConnectionState.Open))
207
						{
208
							using (SQLiteCommand cmd = connection.CreateCommand())
209
							{
210
								cmd.CommandText = string.Format(@"
211
								SELECT *
212
								FROM {0}", HMB_LIST);
213
								using (SQLiteDataReader dr = cmd.ExecuteReader())
214
									dt.Load(dr);
215
							}
216

    
217
						}
218
						connection.Close();
219
					}
220
				}
221
				else if (projectInformation.DBType.Equals(DBType.MSSQL))
222
				{
223
					throw new Exception("mssql");
224
				}
225
			}
226
			catch (Exception ex)
227
			{
228
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
229
			}
230
			return dt;
231
		}
232

    
233
		public static DataTable GetSymbolStreamData(string streamNoAttrName)
234
		{
235
			DataTable dt = new DataTable();
236
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
237
			try
238
			{
239
				if (projectInformation.DBType.Equals(DBType.SQLite))
240
				{
241
					using (SQLiteConnection connection = new SQLiteConnection(projectInformation.ConnString, true))
242
					{
243
						connection.Open();
244
						if (connection.State.Equals(ConnectionState.Open))
245
						{
246
							using (SQLiteCommand cmd = connection.CreateCommand())
247
							{
248
								cmd.CommandText = string.Format(@"
249
								SELECT c.UID, c.SYMBOL_UID, a.[VALUE], sa.ATTRIBUTE 
250
								FROM COMPONENTS c, Attributes a, SymbolAttribute sa
251
								WHERE c.UID = a.COMPONENTS_UID AND a.SymbolAttribute_UID = sa.UID AND sa.Attribute = '{0}'", streamNoAttrName);
252
								using (SQLiteDataReader dr = cmd.ExecuteReader())
253
									dt.Load(dr);
254
							}
255

    
256
						}
257
						connection.Close();
258
					}
259
				}
260
				else if (projectInformation.DBType.Equals(DBType.MSSQL))
261
				{
262
					throw new Exception("mssql");
263
				}
264
			}
265
			catch (Exception ex)
266
			{
267
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
268
			}
269
			return dt;
270
		}
271

    
272
		public static DataTable GetSymbolItemData(string itemAttrName)
273
		{
274
			DataTable dt = new DataTable();
275
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
276
			try
277
			{
278
				if (projectInformation.DBType.Equals(DBType.SQLite))
279
				{
280
					using (SQLiteConnection connection = new SQLiteConnection(projectInformation.ConnString, true))
281
					{
282
						connection.Open();
283
						if (connection.State.Equals(ConnectionState.Open))
284
						{
285
							using (SQLiteCommand cmd = connection.CreateCommand())
286
							{
287
								cmd.CommandText = string.Format(@"
288
								SELECT c.UID, c.SYMBOL_UID, a.[VALUE], sa.ATTRIBUTE 
289
								FROM COMPONENTS c, Attributes a, SymbolAttribute sa
290
								WHERE c.UID = a.COMPONENTS_UID AND a.SymbolAttribute_UID = sa.UID AND sa.Attribute = '{0}'", itemAttrName);
291
								using (SQLiteDataReader dr = cmd.ExecuteReader())
292
									dt.Load(dr);
293
							}
294

    
295
						}
296
						connection.Close();
297
					}
298
				}
299
				else if (projectInformation.DBType.Equals(DBType.MSSQL))
300
				{
301
					throw new Exception("mssql");
302
				}
303
			}
304
			catch (Exception ex)
305
			{
306
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
307
			}
308
			return dt;
309
		}
310

    
311
		public static string GetAttributeValue(string componentUID, string attrName)
312
		{
313
			string result = string.Empty;
314

    
315
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
316
			try
317
			{
318
				if (projectInformation.DBType.Equals(DBType.SQLite))
319
				{
320
					using (SQLiteConnection connection = new SQLiteConnection(projectInformation.ConnString, true))
321
					{
322
						connection.Open();
323
						if (connection.State.Equals(ConnectionState.Open))
324
						{
325
							using (SQLiteCommand cmd = connection.CreateCommand())
326
							{
327
								DataTable dt = new DataTable();
328
								cmd.CommandText = string.Format(@"
329
								SELECT c.UID, c.SYMBOL_UID, a.[VALUE], sa.ATTRIBUTE 
330
								FROM COMPONENTS c, Attributes a, SymbolAttribute sa
331
								WHERE c.UID = a.COMPONENTS_UID AND a.SymbolAttribute_UID = sa.UID AND sa.Attribute = '{0}' AND c.UID = '{1}'", attrName, componentUID);
332
								using (SQLiteDataReader dr = cmd.ExecuteReader())
333
									dt.Load(dr);
334

    
335
								if (dt.Rows.Count.Equals(1))
336
									result = dt.Rows[0]["VALUE"].ToString();
337
							}
338

    
339
						}
340
						connection.Close();
341
					}
342
				}
343
				else if (projectInformation.DBType.Equals(DBType.MSSQL))
344
				{
345
					throw new Exception("mssql");
346
				}
347
			}
348
			catch (Exception ex)
349
			{
350
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
351
			}
352

    
353
			return result;
354
		}
355

    
356
		public static DataTable GetProject()
357
		{
358
			DataTable dt = new DataTable();
359
			ProjectInformation projectInformation = ProjectInformation.GetInstance();
360
			try
361
			{
362
				using (SQLiteConnection connection = new SQLiteConnection(@"Data Source = C:\ProgramData\Digital PID\Project.db", true))
363
				{
364
					connection.Open();
365
					if (connection.State.Equals(ConnectionState.Open))
366
					{
367
						using (SQLiteCommand cmd = connection.CreateCommand())
368
						{
369
							cmd.CommandText = "SELECT p.[Id], p.Name, p.Path, s.DBTypes_UID, s.Host, s.[User], s.[Password], s.FilePath FROM DBSettings s, Projects p WHERE s.Projects_UID = p.[Id]";
370
							using (SQLiteDataReader dr = cmd.ExecuteReader())
371
								dt.Load(dr);
372
						}
373

    
374
					}
375
					connection.Close();
376
				}
377
			}
378
			catch (Exception ex)
379
			{
380
				MessageBox.Show(ex.Message, "error", MessageBoxButtons.OK, MessageBoxIcon.Error);
381
			}
382

    
383
            foreach (DataRow row in dt.Rows)
384
            {
385
                string projectDir = row["FilePath"].ToString();
386

    
387
                FileInfo fileInfo = new FileInfo(projectDir);
388
                if (fileInfo.Exists == false)
389
                {
390
                    row.Delete();
391
                }
392
            }
393
            dt.AcceptChanges();
394
            dt.DefaultView.Sort = "Name";
395
            dt = dt.DefaultView.ToTable();
396

    
397
            return dt;
398
		}
399

    
400

    
401
	}
402
}
클립보드 이미지 추가 (최대 크기: 500 MB)