济宁李尔调度
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

264 lines
10 KiB

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using DBFactory;
namespace wcfControlMonitorClient
{
/// <summary>
/// Creator:Richard.liu
/// 接口和监控数据库链接配置维护
/// </summary>
public partial class FrmConnectDB : Form
{
DBOperator dbo = new DBOperator(false);
private string _connectType;
/// <summary>
/// Manage代表管理数据库连接;Monitor代表监控数据库连接
/// </summary>
public string ConnectType
{
get { return _connectType; }
set { _connectType = value; }
}
private static FrmConnectDB _formInstance;
public static FrmConnectDB FormInstance
{
get
{
if (_formInstance == null)
{
_formInstance = new FrmConnectDB();
}
return _formInstance;
}
set { _formInstance = value; }
}
public FrmConnectDB()
{
InitializeComponent();
_formInstance = this;
}
private void FrmConnectDB_Load(object sender, EventArgs e)
{
try
{
string dbf = dbo.GetValue("DBFactory");
string[] temp,connstr;
string server="",dbService="",uid="",pwd="";
char[] dh = new char[1] { '=' };
char[] fh = new char[1] { ';' };
if (_connectType == "Manage")
{
dbf = dbo.GetValue("ManDBFactory");
lblConnType.Text = "接口据库连接配置信息维护";
connstr = dbo.GetValue("ManConnString").Split(fh);
}
else //if (_connectType == "Monitor")
{
dbf = dbo.GetValue("DBFactory");
lblConnType.Text = "调度数据库连接配置信息维护";
connstr = dbo.GetValue("ConnString").Split(fh);
}
for (int i = connstr.GetLowerBound(0); i <= connstr.GetUpperBound(0); i++)
{
temp = connstr[i].Split(dh);
switch (dbf)
{
case "SQLServerDBFactory":
lblserver.Text = "数据库服务器计算机名";
//"Server = (local) ; uid = SA ; pwd =; database = SSWCMS ; MAX Pool Size = 512 "
switch (temp[0].Trim())
{
case "Server":
server = temp[1].Trim();
break;
case "database":
dbService = temp[1].Trim();
break;
case "uid":
uid = temp[1].Trim();
break;
case "pwd":
pwd = temp[1].Trim();
break;
}
break;
case "OracleDBFactory":
lblserver.Text = "服务器名称(可以填任何值)";
//"Data Source=Richard-liu;User ID=pdadmin;Password=pdadmin ; MAX Pool Size = 512 "
switch (temp[0].Trim())
{
case "Data Source":
dbService = temp[1].Trim();
break;
case "User ID":
uid = temp[1].Trim();
break;
case "Password":
pwd = temp[1].Trim();
break;
default:
server = "127.0.0.1";
break;
}
break;
case "OleDBFactory":
//"Provider=OraOLEDB.Oracle.1;Data Source=Richard-liu;User ID=sa;Password= ; MAX Pool Size = 512 "
lblserver.Text = "OLEDB数据库提供者";
switch (temp[0].Trim())
{
case "Data Source":
dbService = temp[1].Trim();
break;
case "User ID":
uid = temp[1].Trim();
break;
case "Password":
pwd = temp[1].Trim();
break;
case "Provider":
server = temp[1].Trim();
break;
}
break;
default:
lblserver.Text = "数据库服务器计算机名";
//"Server = (local) ; uid = SA ; pwd =; database = SSWCMS ; MAX Pool Size = 512 "
switch (temp[0].Trim())
{
case "Server":
server = temp[1].Trim();
break;
case "database":
dbService = temp[1].Trim();
break;
case "uid":
uid = temp[1].Trim();
break;
case "pwd":
pwd = temp[1].Trim();
break;
default:
server = "(local)";
uid = "SA";
dbService = "SSWCMS";
break;
}
break;
}
}
tbserver.Text = server;
tbdbService.Text = dbService;
tbuid.Text = uid;
tbpwd.Text = pwd;
}
catch (Exception ex)
{
throw ex;
}
}
private void btOK_Click(object sender, EventArgs e)
{
if (MessageBox.Show("您确认要保存数据库连接配置文件信息吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK)
{
return;
}
if (this.tbserver.Text.Trim().Length == 0)
{
MessageBox.Show("数据库服务器计算机名不允许是空值!", "误操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Warning);
return;
}
if (this.tbdbService.Text.Trim().Length == 0)
{
MessageBox.Show("数据库服务名称不允许是空值!", "误操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Warning);
return;
}
if (this.tbuid.Text.Trim().Length == 0)
{
MessageBox.Show("登录数据库的用户名不允许是空值!", "误操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Warning);
return;
}
try
{
string dbf = dbo.GetValue("DBFactory");
string key="",connstr="",pwd="";
if (_connectType == "Manage")
{
dbf = dbo.GetValue("ManDBFactory");
key="ManConnString";
}
else //if (_connectType == "Monitor")
{
dbf = dbo.GetValue("DBFactory");
key = "ConnString";
}
if (this.tbpwd.Text.Trim() == "")
{
pwd = null;
}
else
{
pwd = this.tbpwd.Text.Trim();
}
switch (dbf)
{
case "SQLServerDBFactory":
//"Server = (local) ; uid = SA ; pwd =; database = SSWCMS ; MAX Pool Size = 512 "
connstr = "Server = " + tbserver.Text.Trim() + " ; uid = " + tbuid.Text.Trim() + " ; pwd =" + pwd + "; database = " + tbdbService.Text.Trim() + " ; MAX Pool Size = 512 ";
break;
case "OracleDBFactory":
//"Data Source=Richard-liu;User ID=pdadmin;Password=pdadmin ; MAX Pool Size = 512 "
connstr = "Data Source=" + tbdbService.Text.Trim() + " ; User ID= " + tbuid.Text.Trim() + " ; Password=" + pwd + " ; MAX Pool Size = 512 ";
break;
case "OleDBFactory":
//"Provider=OraOLEDB.Oracle.1;Data Source=Richard-liu;User ID=sa;Password= ; MAX Pool Size = 512 "
connstr = "Provider="+ tbserver.Text.Trim() +";Data Source=" + tbdbService.Text.Trim() + " ; User ID= " + tbuid.Text.Trim() + " ; Password=" + pwd + " ; MAX Pool Size = 512 ";
break;
default:
break;
}
dbo.SetValue(key, connstr);
if (MessageBox.Show("数据库连接配置文件信息保存成功!确认要退出本系统,重新启动程序吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Information) == DialogResult.OK)
{
Application.Exit();
}
else
{
this.Close();
}
}
catch (Exception ex)
{
throw ex;
}
}
private void btCancel_Click(object sender, EventArgs e)
{
this.Close();
}
private void FrmConnectDB_FormClosing(object sender, FormClosingEventArgs e)
{
_formInstance = null;
}
}
}