在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
public class operateDB { private static string conStr; public static OleDbConnection cnn; OleDbDataAdapter da; OleDbCommandBuilder cb; OleDbCommand cmd; //构造函数 #region initialize public operateDB() { // // TODO: 在此处添加构造函数逻辑 // cnn=new OleDbConnection(); da=new OleDbDataAdapter(); //不用OleDbCommand对象更新到数据库时,必须有下面一行 cb=new OleDbCommandBuilder(da); cmd=new OleDbCommand(); } #endregion initialize //连接字符串 #region get&setConnectionString /// <summary> /// 获取连接字符串 /// </summary> public string MyConStr { get {return conStr;} set {conStr = value;} } #endregion get&setConnectionString //获得表的名称 #region acquireTableNames /// <summary> /// 获取数据库中的表名集合 /// </summary> /// <returns></returns> public DataTable tablesCollection() { DataTable tbl=new DataTable(); try { cnn.ConnectionString=conStr; cnn.Open(); tbl = cnn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] {null, null, null, "TABLE"}); } catch(Exception ce) { Console.WriteLine("产生错误:\n{0}",ce.Message); } finally { cnn.Close(); } return tbl; } #endregion acquireTableNames //填充数据 #region fillTable /// <summary> /// 填充dataTable的查询 /// </summary> /// <param name="tblName">数据表(必须输入数据库中存在的名称,也可以是视图)</param> /// <param name="sqlStr">SQL语句</param> /// <returns>记录条数</returns> public int select(DataTable tblName,string sqlStr) { int i=0; // try // { // tblName.Clear(); da.Dispose(); if (cnn.ConnectionString=="") cnn.ConnectionString=conStr; if (cnn.State!=ConnectionState.Open) cnn.Open(); // OleDbCommand cmd=new OleDbCommand("select * from "+tblName.TableName+" where "+sqlStr,cnn); cmd.Connection=cnn; cmd.CommandType=CommandType.Text; cmd.CommandText="select * from "+tblName.TableName+" where "+sqlStr; da.SelectCommand=cmd; i=da.Fill(tblName); // // // } // catch(Exception ce) // { // Console.WriteLine("产生错误:\n{0}",ce.Message); // } // finally // { //this.da.Dispose(); cnn.Close(); // } return i; } #endregion fillTable //插入记录 #region insert(use CommandBuilder) /// <summary> /// 插入记录(用OleDbCommandBuilder) /// </summary> /// <param name="tblName">数据表</param> /// <param name="newRow">与表中字段对应的新行</param> /// <returns>影响的行数</returns> public int insert(DataTable tblName,DataRow newRow) { cnn.Open(); int i=0; // // try // { //如何判断OleDbDataAdapter是否已经Dispose //下面如果不生成新的OleDbDataAdapter、OleDbCommandBuilder、OleDbCommand, //而用原来的全局da,cb,cmd,则在一次操作中只能更新一张表 OleDbDataAdapter daIn=new OleDbDataAdapter(); OleDbCommandBuilder cbIn=new OleDbCommandBuilder(daIn); OleDbCommand cmdIn=new OleDbCommand("select * from "+tblName.TableName,cnn); daIn.SelectCommand=cmdIn; // foreach (DataTable dt in da.TableMappings) // { // if (dt.TableName!=tblName.TableName) // dt.Clear(); // } tblName.Rows.Add(newRow); i=daIn.Update(tblName); // // } // catch(Exception ce) // { // Console.WriteLine("产生错误:\n{0}",ce.Message); // } // finally // { // cnn.Close(); // } // cnn.Close(); return i; } #endregion insert(use CommandBuilder) //插入记录 #region insert(use InsideTransaction,DataTable[]) public string insert(DataTable[] tbls,DataRow[] newRows) { int[] num=new int[tbls.Length]; int sum=0; bool judge=false; string str=""; if (tbls.Length==newRows.Length) { cnn.Open(); OleDbTransaction tran=cnn.BeginTransaction(); for (int i=0;i<tbls.Length;i++) { // this.select(tbls[i],"1=1",tran); da.InsertCommand=insertCmd(tbls[i],"操作编号"); tbls[i].Rows.Add(newRows[i]); da.InsertCommand.Transaction=tran; try { num[i]=da.Update(tbls[i]); sum+=num[i]; } catch { sum=-1; } if (num[i]==0) judge=true; } if (judge) { tran.Rollback(); str="更新失败"; sum=0; } else { tran.Commit(); str="更新成功"; } } cnn.Close(); return str+",影响了 "+sum.ToString()+" 条记录"; } #endregion insert(use InsideTransaction,DataTable[]) //插入记录 #region insert(use OutsideTransaction) /// <summary> /// 填充DataTable(用于事务处理) /// </summary> /// <param name="tblName">表</param> /// <param name="sqlStr">SQL语句</param> /// <param name="trs">Transaction对象</param> /// <returns>行数</returns> public int select(DataTable tblName,string sqlStr,OleDbTransaction trs) { int i=0; // try // { // tblName.Clear(); da.Dispose(); if (cnn.ConnectionString=="") cnn.ConnectionString=conStr; if (cnn.State!=ConnectionState.Open) cnn.Open(); // OleDbCommand cmd=new OleDbCommand("select * from "+tblName.TableName+" where "+sqlStr,cnn); cmd.Connection=cnn; cmd.CommandType=CommandType.Text; cmd.CommandText="select * from "+tblName.TableName+" where "+sqlStr; da.SelectCommand=cmd; cmd.Transaction=trs; i=da.Fill(tblName); return i; } /// <summary> /// 插入记录(用OleDbDataAdapter.Update方法及OleDbTransaction) /// </summary> /// <param name="tblName">数据表</param> /// <param name="newRow">新行</param> /// <param name="trs">事务对象</param> /// <returns></returns> public int insert(DataTable tblName,DataRow newRow,OleDbTransaction trs) { da.InsertCommand=insertCmd(tblName,"noo"); int num=0; try { tblName.Rows.Add(newRow); da.InsertCommand.Transaction=trs; num=da.Update(tblName); } catch { } return num; } #endregion insert(use OutsideTransaction) //构造插入的Command #region insertCommand /// <summary> /// 构造insertCommand /// </summary> /// <param name="dtl">数据表</param> /// <param name="identityCol">identity列的名称</param> /// <returns></returns> private static OleDbCommand insertCmd(DataTable dtl,string identityCol) { OleDbCommand inCmd=new OleDbCommand(); inCmd.Connection=cnn; string sqlStr=""; string strValue=""; sqlStr = "INSERT " + dtl.TableName.ToString() + "("; strValue = ") Values ("; for (int i=0;i<dtl.Columns.Count;i++) { //对于IDENTITY列无需赋值 if (dtl.Columns[i].ToString() != identityCol) { sqlStr += "[" + dtl.Columns[i].ToString() + "], "; strValue +="?,"; OleDbParameter myPara = new OleDbParameter(); myPara.ParameterName = "@" + dtl.Columns[i].ToString(); myPara.OleDbType = GetOleDbType(dtl.Columns[i].DataType.ToString()); // myPara.Direction = ParameterDirection.Input; myPara.SourceColumn = dtl.Columns[i].ToString(); // myPara.SourceVersion = DataRowVersion.Current; inCmd.Parameters.Add(myPara); } } sqlStr=sqlStr.Substring(0,sqlStr.Length-2); strValue=strValue.Substring(0,strValue.Length-1); sqlStr += strValue + ")"; inCmd.CommandText = sqlStr; return inCmd; } #endregion insertCommand //修改 #region update /// <summary> /// 修改记录 /// </summary> /// <param name="tblName">数据表</param> /// <param name="strUp">SQL语句</param> /// <returns>影响的行数</returns> public int update(DataTable tblName,string strUp) { cnn.Close(); return i; } #endregion update //删除 #region del(use CommandBuilder) /// <summary> /// 删除记录 /// </summary> /// <param name="tblName">数据表</param> /// <param name="strDel">SQL语句</param> /// <returns>影响的行数</returns> public int delete(DataTable tblName,string strDel) //strDel是删除条件 { int rows=0; //用OleDbDataAdapter.Update方法自动更新必须在where中存在主键或唯一值 // try // { // cnn.Open(); rows=tblName.Rows.Count; for (int i=0;i< tblName.Rows.Count;i++) { tblName.Rows[i].Delete(); } //注意,如在da.Update前面用了下面的AcceptChanges方法,因为记录被删除--更新到数据库失败 //tblName.AcceptChanges(); da.Update(tblName); // // } // catch(Exception ce) // { // Console.WriteLine("产生错误:\n{0}",ce.Message); // } // finally // { cnn.Close(); // } /// //用OleDbCommand直接更新 // try // { // string str="delete from "+tblName.TableName+" where "+strDel; // cnn.Open(); // OleDbCommand cmdD=new OleDbCommand(str,cnn); // cmdD.CommandType=CommandType.Text; // rows=cmdD.ExecuteNonQuery(); // } // // catch(Exception ce) // { // Console.WriteLine("产生错误:\n{0}",ce.Message); // } // finally // { // cnn.Close(); // } return rows; } #endregion del(use CommandBuilder) //构造删除的Command #region delCommand(create OleDbDataAdapter.deleteCommand) public int delete(DataTable tblName) { int rows=0; da.DeleteCommand=delCmd(tblName); for (int i=0;i< tblName.Rows.Count;i++) { tblName.Rows[i].Delete(); } rows=da.Update(tblName); return rows; } private static OleDbCommand delCmd(DataTable dtl) { OleDbCommand delCmd=new OleDbCommand(); delCmd.Connection=cnn; string sqlStr=""; sqlStr = "delete from " + dtl.TableName.ToString() + " where "; for (int i=0;i<dtl.Columns.Count;i++) { sqlStr += "([" + dtl.Columns[i].ToString() + "] = ? OR ? IS NULL AND ["+dtl.Columns[i].ToString()+"] IS NULL) AND"; OleDbParameter myPara = new OleDbParameter(); myPara.ParameterName = "or1_" + dtl.Columns[i].ToString(); myPara.OleDbType = GetOleDbType(dtl.Columns[i].DataType.ToString()); myPara.Direction = ParameterDirection.Input; myPara.SourceColumn = dtl.Columns[i].ToString(); myPara.SourceVersion = DataRowVersion.Original; delCmd.Parameters.Add(myPara); int j=delCmd.Parameters.Count; bool b=dtl.Columns[i].AllowDBNull; if (b) { OleDbParameter myPara1 = new OleDbParameter(); myPara1.ParameterName = "or2_" + dtl.Columns[i].ToString(); myPara1.OleDbType = GetOleDbType(dtl.Columns[i].DataType.ToString()); myPara1.Direction = ParameterDirection.Input; myPara1.SourceColumn = dtl.Columns[i].ToString(); myPara1.SourceVersion = DataRowVersion.Original; delCmd.Parameters.Add(myPara1); j=delCmd.Parameters.Count; } } sqlStr=sqlStr.Substring(0,sqlStr.Length-3); delCmd.CommandText = sqlStr; return delCmd; } #endregion delCommand(create OleDbDataAdapter.deleteCommand) #region amendDataBase public void addColumn(DataTable tblName,string strUp) //修改表的结构,更新到数据库 { cnn.Open(); // OleDbCommand cmdS=new OleDbCommand("select * from "+tblName.TableName,cnn); // da.SelectCommand=cmdS; // OleDbCommandBuilder cb=new OleDbCommandBuilder(da); // DataColumn colItem = new DataColumn(strUp,Type.GetType("System.String")); // // tblName.Columns.Add(colItem); //为什么上面的方法不行,只能直接用SQL语句吗? da.Fill(tblName); da.Update(tblName); } #endregion amendDataBase //调用存储过程 #region execProc(return dataTable) /// <summary> /// 执行存储过程 /// </summary> /// <param name="procName">存储过程名字</param> /// <param name="ParaValue">参数的值</param> /// <param name="ParaName">参数名字</param> /// <param name="ParaType">参数的类型</param> /// <returns></returns> public DataTable ExecProc(string procName,string[] ParaValue,string[] ParaName,string[] ParaType) { OleDbCommand cmdp=new OleDbCommand(); cmdp.Connection=cnn; cmdp.CommandType=CommandType.StoredProcedure; cmdp.CommandText=procName; for (int i=0;i<ParaName.Length;i++) { OleDbParameter pt=new OleDbParameter(); ParaName[i]="@"+ParaName[i]; //参数名字 //pt.ParameterName=ParaName[i]; pt.SourceColumn=ParaName[i]; pt.OleDbType=GetOleDbType(ParaType[i]); pt.Value=ParaValue[i]; cmdp.Parameters.Add(pt); } DataTable dtl=new DataTable(); cnn.Open(); da.SelectCommand=cmdp; da.Fill(dtl); cnn.Close(); return dtl; } /// <summary> /// 设置OleDbParameter对象的DbType(把字符串变为相应的OleDbType类型) /// </summary> /// <param name="type">传入参数的字符串</param> /// <returns></returns> private static OleDbType GetOleDbType(string type) { // try // { // return (OleDbType)Enum.Parse(typeof(OleDbType), type, true); // } // catch // { // return OleDbType.Varchar; // } switch (type) { case "date": return OleDbType.DBDate; break; case "num": return OleDbType.Integer; break; default: return OleDbType.VarChar; } } #endregion execProc(return dataTable) } |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论