diff --git a/.vs/ExportDataToFile/v16/.suo b/.vs/ExportDataToFile/v16/.suo
index f248280..68f75e1 100644
Binary files a/.vs/ExportDataToFile/v16/.suo and b/.vs/ExportDataToFile/v16/.suo differ
diff --git a/Form1.Designer.cs b/Form1.Designer.cs
index 319b130..54c7d18 100644
--- a/Form1.Designer.cs
+++ b/Form1.Designer.cs
@@ -55,27 +55,27 @@ namespace ExportDataToFile
this.txtSourcePWD = new System.Windows.Forms.TextBox();
this.label5 = new System.Windows.Forms.Label();
this.dgvExportList = new System.Windows.Forms.DataGridView();
- this.clExport = new System.Windows.Forms.DataGridViewCheckBoxColumn();
- this.clCancel = new System.Windows.Forms.DataGridViewButtonColumn();
- this.clSourceTable = new System.Windows.Forms.DataGridViewTextBoxColumn();
- this.clTargetTable = new System.Windows.Forms.DataGridViewTextBoxColumn();
- this.clTableDel = new System.Windows.Forms.DataGridViewCheckBoxColumn();
- this.clDataTrim = new System.Windows.Forms.DataGridViewCheckBoxColumn();
- this.clMaxRecord = new System.Windows.Forms.DataGridViewTextBoxColumn();
- this.clWhere = new System.Windows.Forms.DataGridViewTextBoxColumn();
- this.clMappingData = new System.Windows.Forms.DataGridViewTextBoxColumn();
this.label11 = new System.Windows.Forms.Label();
this.dgvColumnMapping = new System.Windows.Forms.DataGridView();
- this.clExpColumn = new System.Windows.Forms.DataGridViewCheckBoxColumn();
- this.clClean = new System.Windows.Forms.DataGridViewButtonColumn();
- this.clSourceColumn = new System.Windows.Forms.DataGridViewTextBoxColumn();
- this.clTargetColumn = new System.Windows.Forms.DataGridViewComboBoxColumn();
this.txtWhere = new System.Windows.Forms.TextBox();
this.label13 = new System.Windows.Forms.Label();
this.label14 = new System.Windows.Forms.Label();
this.cbTargetTable = new System.Windows.Forms.ComboBox();
this.btnMapping = new System.Windows.Forms.Button();
this.sfPath = new System.Windows.Forms.SaveFileDialog();
+ this.clExpColumn = new System.Windows.Forms.DataGridViewCheckBoxColumn();
+ this.clClean = new System.Windows.Forms.DataGridViewButtonColumn();
+ this.clSourceColumn = new System.Windows.Forms.DataGridViewTextBoxColumn();
+ this.clType = new System.Windows.Forms.DataGridViewTextBoxColumn();
+ this.clTargetColumn = new System.Windows.Forms.DataGridViewComboBoxColumn();
+ this.clExport = new System.Windows.Forms.DataGridViewCheckBoxColumn();
+ this.clCancel = new System.Windows.Forms.DataGridViewButtonColumn();
+ this.clSourceTable = new System.Windows.Forms.DataGridViewTextBoxColumn();
+ this.clTargetTable = new System.Windows.Forms.DataGridViewTextBoxColumn();
+ this.clTableDel = new System.Windows.Forms.DataGridViewCheckBoxColumn();
+ this.clMaxRecord = new System.Windows.Forms.DataGridViewTextBoxColumn();
+ this.clWhere = new System.Windows.Forms.DataGridViewTextBoxColumn();
+ this.clMappingData = new System.Windows.Forms.DataGridViewTextBoxColumn();
((System.ComponentModel.ISupportInitialize)(this.dgvExportList)).BeginInit();
((System.ComponentModel.ISupportInitialize)(this.dgvColumnMapping)).BeginInit();
this.SuspendLayout();
@@ -247,6 +247,7 @@ namespace ExportDataToFile
// btnExport
//
this.btnExport.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
+ this.btnExport.Enabled = false;
this.btnExport.Location = new System.Drawing.Point(1649, 85);
this.btnExport.Name = "btnExport";
this.btnExport.Size = new System.Drawing.Size(135, 30);
@@ -259,7 +260,7 @@ namespace ExportDataToFile
//
this.label12.AutoSize = true;
this.label12.ForeColor = System.Drawing.SystemColors.ControlLight;
- this.label12.Location = new System.Drawing.Point(1293, 157);
+ this.label12.Location = new System.Drawing.Point(1224, 157);
this.label12.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
this.label12.Name = "label12";
this.label12.Size = new System.Drawing.Size(73, 20);
@@ -343,87 +344,18 @@ namespace ExportDataToFile
this.clSourceTable,
this.clTargetTable,
this.clTableDel,
- this.clDataTrim,
this.clMaxRecord,
this.clWhere,
this.clMappingData});
this.dgvExportList.Location = new System.Drawing.Point(18, 125);
this.dgvExportList.Name = "dgvExportList";
this.dgvExportList.RowTemplate.Height = 25;
- this.dgvExportList.Size = new System.Drawing.Size(1257, 924);
+ this.dgvExportList.Size = new System.Drawing.Size(1204, 924);
this.dgvExportList.TabIndex = 44;
this.dgvExportList.CellClick += new System.Windows.Forms.DataGridViewCellEventHandler(this.dgvExportList_CellClick);
this.dgvExportList.CellContentClick += new System.Windows.Forms.DataGridViewCellEventHandler(this.dgvExportList_CellContentClick);
this.dgvExportList.CellEndEdit += new System.Windows.Forms.DataGridViewCellEventHandler(this.dgvExportList_CellEndEdit);
//
- // clExport
- //
- this.clExport.FalseValue = "false";
- this.clExport.Frozen = true;
- this.clExport.HeaderText = "匯出";
- this.clExport.IndeterminateValue = "false";
- this.clExport.Name = "clExport";
- this.clExport.ReadOnly = true;
- this.clExport.TrueValue = "true";
- this.clExport.Width = 55;
- //
- // clCancel
- //
- this.clCancel.Frozen = true;
- this.clCancel.HeaderText = "清除";
- this.clCancel.Name = "clCancel";
- this.clCancel.Text = "Clean";
- this.clCancel.Width = 55;
- //
- // clSourceTable
- //
- this.clSourceTable.DataPropertyName = "TableName";
- this.clSourceTable.Frozen = true;
- this.clSourceTable.HeaderText = "來源資料表名稱";
- this.clSourceTable.Name = "clSourceTable";
- this.clSourceTable.ReadOnly = true;
- this.clSourceTable.Resizable = System.Windows.Forms.DataGridViewTriState.True;
- this.clSourceTable.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
- this.clSourceTable.Width = 250;
- //
- // clTargetTable
- //
- this.clTargetTable.HeaderText = "目標資料表名稱";
- this.clTargetTable.Name = "clTargetTable";
- this.clTargetTable.ReadOnly = true;
- this.clTargetTable.Resizable = System.Windows.Forms.DataGridViewTriState.True;
- this.clTargetTable.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
- this.clTargetTable.Width = 250;
- //
- // clTableDel
- //
- this.clTableDel.HeaderText = "清除目標資料表內容";
- this.clTableDel.Name = "clTableDel";
- this.clTableDel.Width = 180;
- //
- // clDataTrim
- //
- this.clDataTrim.HeaderText = "清除尾段空白";
- this.clDataTrim.Name = "clDataTrim";
- this.clDataTrim.Width = 120;
- //
- // clMaxRecord
- //
- this.clMaxRecord.HeaderText = "檔案匯出上限筆數";
- this.clMaxRecord.Name = "clMaxRecord";
- this.clMaxRecord.Width = 180;
- //
- // clWhere
- //
- this.clWhere.HeaderText = "過濾條件";
- this.clWhere.Name = "clWhere";
- this.clWhere.Width = 200;
- //
- // clMappingData
- //
- this.clMappingData.HeaderText = "欄位對應";
- this.clMappingData.Name = "clMappingData";
- //
// label11
//
this.label11.AutoSize = true;
@@ -447,62 +379,32 @@ namespace ExportDataToFile
this.clExpColumn,
this.clClean,
this.clSourceColumn,
+ this.clType,
this.clTargetColumn});
- this.dgvColumnMapping.Location = new System.Drawing.Point(1297, 180);
+ this.dgvColumnMapping.Location = new System.Drawing.Point(1228, 180);
this.dgvColumnMapping.Name = "dgvColumnMapping";
this.dgvColumnMapping.RowTemplate.Height = 25;
- this.dgvColumnMapping.Size = new System.Drawing.Size(487, 342);
+ this.dgvColumnMapping.Size = new System.Drawing.Size(556, 342);
this.dgvColumnMapping.TabIndex = 45;
this.dgvColumnMapping.CellContentClick += new System.Windows.Forms.DataGridViewCellEventHandler(this.dgvColumnMapping_CellContentClick);
this.dgvColumnMapping.CellEndEdit += new System.Windows.Forms.DataGridViewCellEventHandler(this.dgvColumnMapping_CellEndEdit);
//
- // clExpColumn
- //
- this.clExpColumn.HeaderText = "匯出";
- this.clExpColumn.Name = "clExpColumn";
- this.clExpColumn.Resizable = System.Windows.Forms.DataGridViewTriState.True;
- this.clExpColumn.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.Automatic;
- this.clExpColumn.Width = 65;
- //
- // clClean
- //
- this.clClean.HeaderText = "清除";
- this.clClean.Name = "clClean";
- this.clClean.Width = 50;
- //
- // clSourceColumn
- //
- this.clSourceColumn.DataPropertyName = "COLUMN_NAME";
- this.clSourceColumn.HeaderText = "來源欄位";
- this.clSourceColumn.Name = "clSourceColumn";
- this.clSourceColumn.ReadOnly = true;
- this.clSourceColumn.Resizable = System.Windows.Forms.DataGridViewTriState.True;
- this.clSourceColumn.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
- this.clSourceColumn.Width = 200;
- //
- // clTargetColumn
- //
- this.clTargetColumn.HeaderText = "目標欄位";
- this.clTargetColumn.Name = "clTargetColumn";
- this.clTargetColumn.Resizable = System.Windows.Forms.DataGridViewTriState.True;
- this.clTargetColumn.Width = 200;
- //
// txtWhere
//
this.txtWhere.Anchor = ((System.Windows.Forms.AnchorStyles)((((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom)
| System.Windows.Forms.AnchorStyles.Left)
| System.Windows.Forms.AnchorStyles.Right)));
- this.txtWhere.Location = new System.Drawing.Point(1297, 556);
+ this.txtWhere.Location = new System.Drawing.Point(1228, 556);
this.txtWhere.Multiline = true;
this.txtWhere.Name = "txtWhere";
- this.txtWhere.Size = new System.Drawing.Size(487, 457);
+ this.txtWhere.Size = new System.Drawing.Size(556, 457);
this.txtWhere.TabIndex = 47;
//
// label13
//
this.label13.AutoSize = true;
this.label13.ForeColor = System.Drawing.SystemColors.ControlLight;
- this.label13.Location = new System.Drawing.Point(1297, 533);
+ this.label13.Location = new System.Drawing.Point(1228, 533);
this.label13.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
this.label13.Name = "label13";
this.label13.Size = new System.Drawing.Size(73, 20);
@@ -513,7 +415,7 @@ namespace ExportDataToFile
//
this.label14.AutoSize = true;
this.label14.ForeColor = System.Drawing.SystemColors.ControlLight;
- this.label14.Location = new System.Drawing.Point(1293, 125);
+ this.label14.Location = new System.Drawing.Point(1224, 125);
this.label14.Margin = new System.Windows.Forms.Padding(4, 0, 4, 0);
this.label14.Name = "label14";
this.label14.Size = new System.Drawing.Size(89, 20);
@@ -527,9 +429,9 @@ namespace ExportDataToFile
this.cbTargetTable.DisplayMember = "TableName";
this.cbTargetTable.Enabled = false;
this.cbTargetTable.FormattingEnabled = true;
- this.cbTargetTable.Location = new System.Drawing.Point(1389, 122);
+ this.cbTargetTable.Location = new System.Drawing.Point(1320, 122);
this.cbTargetTable.Name = "cbTargetTable";
- this.cbTargetTable.Size = new System.Drawing.Size(395, 28);
+ this.cbTargetTable.Size = new System.Drawing.Size(464, 28);
this.cbTargetTable.TabIndex = 49;
this.cbTargetTable.ValueMember = "TableName";
this.cbTargetTable.SelectedIndexChanged += new System.EventHandler(this.cbTargetTable_SelectedIndexChanged);
@@ -545,6 +447,108 @@ namespace ExportDataToFile
this.btnMapping.UseVisualStyleBackColor = true;
this.btnMapping.Click += new System.EventHandler(this.btnMapping_Click);
//
+ // clExpColumn
+ //
+ this.clExpColumn.HeaderText = "匯出";
+ this.clExpColumn.Name = "clExpColumn";
+ this.clExpColumn.Resizable = System.Windows.Forms.DataGridViewTriState.True;
+ this.clExpColumn.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.Automatic;
+ this.clExpColumn.Width = 65;
+ //
+ // clClean
+ //
+ this.clClean.HeaderText = "清除";
+ this.clClean.Name = "clClean";
+ this.clClean.Width = 50;
+ //
+ // clSourceColumn
+ //
+ this.clSourceColumn.DataPropertyName = "COLUMN_NAME";
+ this.clSourceColumn.HeaderText = "來源欄位";
+ this.clSourceColumn.Name = "clSourceColumn";
+ this.clSourceColumn.ReadOnly = true;
+ this.clSourceColumn.Resizable = System.Windows.Forms.DataGridViewTriState.True;
+ this.clSourceColumn.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
+ this.clSourceColumn.Width = 200;
+ //
+ // clType
+ //
+ this.clType.DataPropertyName = "DATA_TYPE";
+ this.clType.HeaderText = "型態";
+ this.clType.Name = "clType";
+ this.clType.Width = 80;
+ //
+ // clTargetColumn
+ //
+ this.clTargetColumn.HeaderText = "目標欄位";
+ this.clTargetColumn.Name = "clTargetColumn";
+ this.clTargetColumn.Resizable = System.Windows.Forms.DataGridViewTriState.True;
+ this.clTargetColumn.Width = 200;
+ //
+ // clExport
+ //
+ this.clExport.FalseValue = "false";
+ this.clExport.Frozen = true;
+ this.clExport.HeaderText = "匯出";
+ this.clExport.IndeterminateValue = "false";
+ this.clExport.Name = "clExport";
+ this.clExport.ReadOnly = true;
+ this.clExport.TrueValue = "true";
+ this.clExport.Width = 55;
+ //
+ // clCancel
+ //
+ this.clCancel.Frozen = true;
+ this.clCancel.HeaderText = "清除";
+ this.clCancel.Name = "clCancel";
+ this.clCancel.Text = "Clean";
+ this.clCancel.Width = 55;
+ //
+ // clSourceTable
+ //
+ this.clSourceTable.DataPropertyName = "TableName";
+ this.clSourceTable.Frozen = true;
+ this.clSourceTable.HeaderText = "來源資料表名稱";
+ this.clSourceTable.Name = "clSourceTable";
+ this.clSourceTable.ReadOnly = true;
+ this.clSourceTable.Resizable = System.Windows.Forms.DataGridViewTriState.True;
+ this.clSourceTable.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
+ this.clSourceTable.Width = 300;
+ //
+ // clTargetTable
+ //
+ this.clTargetTable.HeaderText = "目標資料表名稱";
+ this.clTargetTable.Name = "clTargetTable";
+ this.clTargetTable.ReadOnly = true;
+ this.clTargetTable.Resizable = System.Windows.Forms.DataGridViewTriState.True;
+ this.clTargetTable.SortMode = System.Windows.Forms.DataGridViewColumnSortMode.NotSortable;
+ this.clTargetTable.Width = 300;
+ //
+ // clTableDel
+ //
+ this.clTableDel.HeaderText = "清除目標資料表內容";
+ this.clTableDel.Name = "clTableDel";
+ this.clTableDel.Width = 180;
+ //
+ // clMaxRecord
+ //
+ this.clMaxRecord.HeaderText = "檔案匯出上限筆數";
+ this.clMaxRecord.Name = "clMaxRecord";
+ this.clMaxRecord.Width = 160;
+ //
+ // clWhere
+ //
+ this.clWhere.HeaderText = "過濾條件";
+ this.clWhere.Name = "clWhere";
+ this.clWhere.Visible = false;
+ this.clWhere.Width = 200;
+ //
+ // clMappingData
+ //
+ this.clMappingData.HeaderText = "欄位對應";
+ this.clMappingData.Name = "clMappingData";
+ this.clMappingData.Visible = false;
+ //
// Form1
//
this.AutoScaleDimensions = new System.Drawing.SizeF(10F, 20F);
@@ -631,21 +635,21 @@ namespace ExportDataToFile
private System.Windows.Forms.Label label13;
private System.Windows.Forms.Label label14;
private System.Windows.Forms.ComboBox cbTargetTable;
+ private System.Windows.Forms.Button btnMapping;
+ private System.Windows.Forms.SaveFileDialog sfPath;
private System.Windows.Forms.DataGridViewCheckBoxColumn clExpColumn;
private System.Windows.Forms.DataGridViewButtonColumn clClean;
private System.Windows.Forms.DataGridViewTextBoxColumn clSourceColumn;
+ private System.Windows.Forms.DataGridViewTextBoxColumn clType;
private System.Windows.Forms.DataGridViewComboBoxColumn clTargetColumn;
- private System.Windows.Forms.Button btnMapping;
private System.Windows.Forms.DataGridViewCheckBoxColumn clExport;
private System.Windows.Forms.DataGridViewButtonColumn clCancel;
private System.Windows.Forms.DataGridViewTextBoxColumn clSourceTable;
private System.Windows.Forms.DataGridViewTextBoxColumn clTargetTable;
private System.Windows.Forms.DataGridViewCheckBoxColumn clTableDel;
- private System.Windows.Forms.DataGridViewCheckBoxColumn clDataTrim;
private System.Windows.Forms.DataGridViewTextBoxColumn clMaxRecord;
private System.Windows.Forms.DataGridViewTextBoxColumn clWhere;
private System.Windows.Forms.DataGridViewTextBoxColumn clMappingData;
- private System.Windows.Forms.SaveFileDialog sfPath;
}
}
diff --git a/Form1.cs b/Form1.cs
index 4743768..2a21657 100644
--- a/Form1.cs
+++ b/Form1.cs
@@ -57,6 +57,7 @@ namespace ExportDataToFile
break;
}
+ EnableExport(); //啟動匯出鈕
}
else
{
@@ -89,6 +90,8 @@ namespace ExportDataToFile
{
if (cbTargetClass.Enabled)
{
+ LockTargetForm();
+
switch (cbTargetClass.SelectedItem.ToString().Trim())
{
case "MS-SQL":
@@ -108,7 +111,7 @@ namespace ExportDataToFile
break;
}
- LockTargetForm();
+ EnableExport(); //啟動匯出鈕
}
else
{
@@ -244,15 +247,23 @@ namespace ExportDataToFile
{
try
{
- if (cbSourceClass.SelectedIndex != -1)
+ if (cbSourceClass.SelectedIndex > 0)
{
string strPath = "";
- sfPath.ShowDialog();
+ sfPath.AddExtension = false;
+ sfPath.Filter = "All files (*.*)|*.*|SQL Files(*.sql)|*.sql|txt files(*.txt)|*.txt";
+ sfPath.FileName = "Output" + DateTime.Now.ToString("_yyyyMMddHHmmss");
+
+
+ if (sfPath.ShowDialog() == DialogResult.Cancel) //如果按下取消,放棄後面動作
+ return;
+
strPath = sfPath.FileName;
+
switch (cbSourceClass.SelectedItem.ToString().Trim())
{
case "MS-SQL": //匯出MS-SQL檔
- ExportMSSQLData(strPath);
+ ExportMSSQLData(sfPath.FileName,sfPath.DefaultExt);
break;
case "MySQL":
@@ -283,6 +294,9 @@ namespace ExportDataToFile
private void btnMapping_Click(object sender, EventArgs e)
{
+ if (dgvColumnMapping.DataSource == null)
+ return;
+
//自動預設產生所有的Mapping檔案
dgvExportList.Rows[intExportIndex].Cells["clMappingData"].Value = GenMappingColumn();
dgvExportList.Rows[intExportIndex].Cells["clExport"].Value = true;
@@ -350,7 +364,7 @@ namespace ExportDataToFile
{
try
{
- string strGetMSSQLColumnList = "Select COLUMN_NAME From INFORMATION_SCHEMA.COLUMNS Where TABLE_NAME ='" + strTableName + "' Order by ORDINAL_POSITION";
+ string strGetMSSQLColumnList = "Select COLUMN_NAME,DATA_TYPE From INFORMATION_SCHEMA.COLUMNS Where TABLE_NAME ='" + strTableName + "' Order by ORDINAL_POSITION";
dgvColumnMapping.DataSource = MSSQLUtility.GetSQLResult(strGetMSSQLColumnList, sqlConn).Tables["Result"];
}
catch (Exception ex)
@@ -374,18 +388,22 @@ namespace ExportDataToFile
}
}
- private void ExportMSSQLData(string strPath)
+ private void ExportMSSQLData(string strPath,string subFileName)
{
+ int intDataCount = 0;
+ int intMaxData = 0;
string strSourceColumns = "";
string strSourceCol = "";
string strSourceTable = "";
+ string strSourceType = "";
string strTargetColumns = "";
string strTargetCol = "";
string strTargetTable = "";
+ string strDeleteCommand = "";
string strValues = "";
string[] strColumns = null;
+ string[,] strColumnResults = new string[dgvExportList.Rows.Count, 2];
StringBuilder sbSelectCommand = new StringBuilder();
- StringBuilder sbInsertCommand = new StringBuilder();
//命令字串處理
strSourceColumns = "";
@@ -396,26 +414,38 @@ namespace ExportDataToFile
{
if (dgvRow.Cells["clExport"].Value != null)
{
+ intDataCount = 0;
+ intMaxData = 0;
strColumns = null;
sbSelectCommand.Clear();
- sbInsertCommand.Clear();
strSourceTable = "";
strSourceColumns = "";
+ strSourceType = "";
strTargetTable = "";
strTargetColumns = "";
+ strDeleteCommand = "";
strValues = "";
DataTable dtResult = null;
+ //取得欄位對應
if (dgvRow.Cells["clMappingData"].Value != null)
{
strColumns = dgvRow.Cells["clMappingData"].Value.ToString().Split('|');
}
+ //取得欄位上限
+ if (dgvRow.Cells["clMaxRecord"].Value != null)
+ {
+ intMaxData = Int32.Parse(dgvRow.Cells["clMaxRecord"].Value.ToString());
+ }
+
+ #region 產生來源資料查詢命令
foreach (string RowData in strColumns)
{
strSourceCol = RowData.Substring(0, RowData.IndexOf(',')).Trim();
- strTargetCol = RowData.Substring(RowData.IndexOf(',') + 1).Trim();
+ strSourceType = RowData.Substring(RowData.IndexOf(',') + 1, RowData.IndexOf(';') - 1 - RowData.IndexOf(',')).Trim();
+ strTargetCol = RowData.Substring(RowData.IndexOf(';') + 1).Trim();
if (strTargetCol == "")
{
@@ -423,15 +453,15 @@ namespace ExportDataToFile
}
if (strSourceColumns == "")
- {
- strSourceColumns += "[" + strSourceCol + "] AS '" + strTargetCol + "'";
- strTargetColumns += strTargetCol;
+ {
+ strSourceColumns += ConvertMSSQLColumnType(strSourceCol, strTargetCol, strSourceType);
+ strTargetColumns += "[" + strTargetCol + "]";
}
else
{
- strSourceColumns += ", [" + strSourceCol + "] AS '" + strTargetCol + "'";
- strTargetColumns += "," + strTargetCol;
- }
+ strSourceColumns += "," + ConvertMSSQLColumnType(strSourceCol, strTargetCol, strSourceType);
+ strTargetColumns += ",[" + strTargetCol + "]";
+ }
}
if (dgvRow.Cells["clSourceTable"].Value != null)
@@ -440,7 +470,6 @@ namespace ExportDataToFile
sbSelectCommand.AppendLine(string.Format("Select {0} From {1} ", strSourceColumns, strSourceTable));
}
-
if (dgvRow.Cells["clWhere"].Value != null)
{
if (dgvRow.Cells["clWhere"].Value.ToString().Trim() != "")
@@ -448,34 +477,77 @@ namespace ExportDataToFile
sbSelectCommand.AppendLine("Where 1=1 And " + dgvRow.Cells["clWhere"].Value.ToString());
}
}
+ #endregion
- //取得完整SQL查詢Command
- //txtWhere.Text = sbResult.ToString();
- //txtWhere.Text = strTargetColumns; 目標欄位對應
+ #region 產生匯出資料語法
dtResult = GetMSSQLResult(sbSelectCommand.ToString()).Tables["Result"];
- foreach (DataRow dr in dtResult.Rows)
- {
- foreach (DataColumn dc in dtResult.Columns)
+ if (dtResult.Rows.Count > 0)
+ {
+ if (dgvRow.Cells["clTargetTable"].Value != null)
{
- if (strValues == "")
+ strTargetTable = dgvRow.Cells["clTargetTable"].Value.ToString();
+ Utility.WriteFile(strPath + ".sql", " ");
+ Utility.WriteFile(strPath + ".sql", string.Format("/*======================================================={0}======================================================*/", strTargetTable));
+ Utility.WriteFile(strPath + ".sql", string.Format("raiserror('Now Insert {0} Datas .... ', 1, 1)", strTargetTable));
+ Utility.WriteFile(strPath + ".sql", "Go");
+ }
+
+ //勾選清除目標資料表
+ if (dgvRow.Cells["clTableDel"].Value != null)
+ {
+ strDeleteCommand = string.Format("Delete From {0} ", strTargetTable);
+
+ if (dgvRow.Cells["clWhere"].Value != null)
{
- strValues = "'" + dr[dc].ToString() + "'";
+ if (dgvRow.Cells["clWhere"].Value.ToString().Trim() != "")
+ {
+ strDeleteCommand += "Where 1=1 And " + dgvRow.Cells["clWhere"].Value.ToString();
+ }
}
- else
+
+ Utility.WriteFile(strPath + ".sql", strDeleteCommand + ";");
+ Utility.WriteFile(strPath + ".sql", "Go");
+ }
+
+ //處理筆數上限似資料匯出
+ string strFileCount = "";
+ foreach (DataRow dr in dtResult.Rows)
+ {
+ strFileCount = (intDataCount / intMaxData).ToString(); //切分檔案
+ foreach (DataColumn dc in dtResult.Columns)
{
- strValues += ",'" + dr[dc].ToString() + "'";
+ if (strValues == "")
+ {
+ strValues = ConvertMSSQLDataType(dr[dc].ToString().Trim(), dc.DataType.ToString());
+ }
+ else
+ {
+ strValues += "," + ConvertMSSQLDataType(dr[dc].ToString().Trim(), dc.DataType.ToString());
+ }
}
- }
- if (dgvRow.Cells["clTargetTable"].Value != null)
- {
- strTargetTable = dgvRow.Cells["clTargetTable"].Value.ToString();
- sbInsertCommand.AppendLine(string.Format("Insert Into {0} ({1}) ",strSourceTable, strValues));
+ if (intMaxData == 0)
+ {
+ //無設定最大筆數
+ Utility.WriteFile(strPath + ".sql", string.Format("Insert Into {0} ({1}) Values ({2}) ", strTargetTable, strTargetColumns, strValues));
+ }
+ else
+ {
+ //有設定最大筆數
+ if (strFileCount == "0")
+ strFileCount = "";
+ Utility.WriteFile(strPath + strFileCount + ".sql", string.Format("Insert Into {0} ({1}) Values ({2}) ", strTargetTable, strTargetColumns, strValues));
+ }
+ intDataCount += 1;
+ strValues = ""; //清除已經存在的資料
}
- }
- }
- Utility.WriteFile(strPath, sbInsertCommand.ToString());
+ Utility.WriteFile(strPath + strFileCount + ".sql", "Go");
+ }
+
+ }
+ #endregion
}
+ MessageBox.Show("匯出完成");
}
#endregion //End of MS-SQL
@@ -486,7 +558,7 @@ namespace ExportDataToFile
{
string strResult = "";
- if (cbSourceClass.SelectedItem == null)
+ if (cbSourceClass.SelectedIndex <= 0)
{
strResult = "請選擇來源資料庫類別";
cbSourceClass.Focus();
@@ -529,8 +601,13 @@ namespace ExportDataToFile
try
{
string strResult = "";
-
- if (cbTargetClass.SelectedItem != null)
+ if (cbTargetClass.SelectedIndex <= 0)
+ {
+ strResult = "請選擇目標資料庫類別";
+ cbTargetClass.Focus();
+ return strResult;
+ }
+ else
{
if (txtTargetIP.Text.Trim() == "")
{
@@ -639,6 +716,7 @@ namespace ExportDataToFile
string strExportColumns = "";
string strSourceColumn = "";
string strTargetColumn = "";
+ string strSourceColType = "";
//預設所有欄位均匯出
foreach (DataGridViewRow dgRow in dgvColumnMapping.Rows)
@@ -657,6 +735,15 @@ namespace ExportDataToFile
strSourceColumn = dgRow.Cells["clSourceColumn"].Value.ToString();
}
+ if (dgRow.Cells["clType"].Value == null)
+ {
+ strSourceColType = " ";
+ }
+ else
+ {
+ strSourceColType = dgRow.Cells["clType"].Value.ToString();
+ }
+
if (dgRow.Cells["clTargetColumn"].Value == null)
{
strTargetColumn = " ";
@@ -669,11 +756,11 @@ namespace ExportDataToFile
if (strExportColumns == "")
{
- strExportColumns += strSourceColumn + "," + strTargetColumn;
+ strExportColumns += strSourceColumn + "," + strSourceColType + ";" + strTargetColumn;
}
else
{
- strExportColumns += "|" + strSourceColumn + "," + strTargetColumn;
+ strExportColumns += "|" + strSourceColumn + "," + strSourceColType + ";" + strTargetColumn;
}
}
}
@@ -779,7 +866,6 @@ namespace ExportDataToFile
senderGrid.Rows[intRowIndex].Cells["clExport"].Value = false;
senderGrid.Rows[intRowIndex].Cells["clTargetTable"].Value = "";
senderGrid.Rows[intRowIndex].Cells["clTableDel"].Value = false;
- senderGrid.Rows[intRowIndex].Cells["clDataTrim"].Value = false;
senderGrid.Rows[intRowIndex].Cells["clMaxRecord"].Value = "";
senderGrid.Rows[intRowIndex].Cells["clWhere"].Value = "";
senderGrid.Rows[intRowIndex].Cells["clMappingData"].Value = "";
@@ -794,8 +880,52 @@ namespace ExportDataToFile
CleanTable.Rows.Clear();
dgvColumnMapping.DataSource = CleanTable;
}
+
+ private void EnableExport()
+ {
+ if (sqlSourceConn.State.ToString().ToUpper() == "OPEN" && sqlTargetConn.State.ToString().ToUpper() == "OPEN")
+ {
+ btnExport.Enabled = true;
+ }
+ }
+
+ private string ConvertMSSQLColumnType(string strSourceCol, string strTargetCol, string strType)
+ {
+ switch (strType.ToUpper())
+ {
+ case "VARCHAR":
+ return "[" + strSourceCol + "] AS " + strTargetCol ;
+ case "VAR":
+ return "[" + strSourceCol + "] AS " + strTargetCol ;
+ case "INT":
+ return "[" + strSourceCol + "] AS " + strTargetCol;
+ case "DATETIME":
+ return "Convert(varchar,[" + strSourceCol + "],21) AS " + strTargetCol;
+ default:
+ return "[" + strSourceCol + "] AS " + strTargetCol;
+ }
+ }
+
+ private string ConvertMSSQLDataType(string strData, string strType)
+ {
+ if(strData == "")
+ {
+ return "Null";
+ }
+ switch (strType.ToUpper())
+ {
+ case "STRING":
+ return "'" + strData.ToString().Trim() + "'";
+ case "INT32":
+ return strData.ToString().Trim();
+ case "DECIMAL":
+ return strData.ToString().Trim();
+ default:
+ return "'" + strData.ToString().Trim() + "'";
+ }
+ }
#endregion
-
+
}
}
diff --git a/Form1.resx b/Form1.resx
index 1727aa0..8a02208 100644
--- a/Form1.resx
+++ b/Form1.resx
@@ -132,9 +132,6 @@
True
-
- True
-
True
@@ -153,6 +150,9 @@
True
+
+ True
+
True