c#下各种数据库操作的封装!(支持ACCESS,SQLSERVER,DB2,ORACLE,MYSQL)

2023-11-17

首先定义数据库操作的标准接口IDBAccess,定义接口的基本功能;

通过基本的接口设置,完成数据访问的统一抽象。

public interface IDBAccess
    
...{
        
void Init(string strServer, string strDataBase, string strUser, string strPwd);
        
void Open();
        
void Close();
        
bool TestConn();
        
int RunNoQuery(string strCmd);
        DataTable RunQuery(
string strCmd);
        DBType DBType 
...get;}
        
int GetFiledMax(string strTable, string strField);
        DataTable Tables 
...get; }
        DataTable GetColumns();
        DataTable GetColumns(
string strTable);
    }

使用静态工厂模式,通过传入枚举型参数 ,动态创建访问实例

实现模式上采用基本实现接口,派生类继承基类的虚函数,从而实现代码的耦合较低,有很好的扩展性。

public enum DBType
    
...{
        Access,
        SQL,
        DB2,
        Oracle,
        MySQL
    }


 
public static class DBAccessFactory
    
...{
        
public static IDBAccess Create(DBType type)
        
...{
            IDBAccess IRet 
= null;
            
switch (type)
            
...{
                
case DBType.Access:
                    IRet 
= new Access(type);
                    
break;

                
case DBType.SQL:
                    IRet 
= new SQL(type);
                    
break;

                
default:
                    
break;
            }

            
return IRet;
        }


        
private abstract class DBAccess : IDBAccess
        
...{
            
protected DbConnection m_oConn = null;
            
protected const string CON_strServer = "Server";
            
protected const string CON_strDataBase = "Data Source";
            
protected const string CON_strUser = "UID";
            
protected const string CON_strPwd = "PWD";
            
protected const string CON_strConnTimeOut = "Connect Timeout = 2";
            
private DBType m_eDBType = DBType.Access;

            
protected DBAccess(DBType type)
            
...{
                
this.m_eDBType = type;
            }


            
public DBType DBType
            
...{
                
get ...return this.m_eDBType; }
            }


            
public void Init(string strServer, string strDataBase, string strUser, string strPwd)
            
...{
                
this.InitConn(strServer, strDataBase, strUser, strPwd);
            }


            
public void Open()
            
...{
                
if (this.m_oConn != null)
                
...{
                    
this.m_oConn.Open();
                }

            }


            
public int RunNoQuery(string strCmd)
            
...{
                
int iRet = 0;
                
try
                
...{
                    DbCommand oCmd 
= this.GetCmd(strCmd);
                    
if (oCmd != null)
                    
...{
                        iRet 
= oCmd.ExecuteNonQuery();
                    }

                }

                
catch (Exception ex)
                
...{
                    
throw (new Exception(ex.Message));
                }

                
return iRet;
            }


            
public int GetFiledMax(string strTable, string strField)
            
...{
                
int iRet = -1;
                DataTable dt 
= this.RunQuery("Select Max(" + strField + ") From " + strTable);
                
if (dt != null && dt.Rows.Count == 1)
                
...{
                    iRet 
= dt.Rows[0][0is DBNull ? 0 : Convert.ToInt32(dt.Rows[0][0]);
                }

                
return iRet;
            }


            
public DataTable RunQuery(string strCmd)
            
...{
                DataTable dt 
= new DataTable();
                DbDataAdapter adp 
= this.DbAdp;
                adp.SelectCommand 
= this.GetCmd(strCmd);
                adp.Fill(dt);
                
return dt;
            }


            
public void Close()
            
...{
                
if (this.m_oConn != null && this.m_oConn.State == System.Data.ConnectionState.Open)
                
...{
                    
this.m_oConn.Close();
                }

            }


            
public bool TestConn()
            
...{
                
bool bRet = true;
                
try
                
...{
                    
if (this.m_oConn.State != System.Data.ConnectionState.Open)
                    
...{
                        
this.m_oConn.Open();
                    }

                    bRet 
= this.m_oConn.State == System.Data.ConnectionState.Open;
                }

                
catch
                
...{
                    bRet 
= false;
                }

                
this.Close();
                
return bRet;
            }


            
public abstract DataTable Tables ...get; }
            
public abstract DataTable GetColumns();
            
public abstract DataTable GetColumns(string strTable);

            
protected abstract void InitConn(string strServer, string strDataBase, string strUser, string strPwd);
            
protected abstract DbCommand GetCmd(string strCmd);
            
protected abstract DbDataAdapter DbAdp ...get;}
        }

   }

各派生类的具体实现,此时只要实现DBAccess的各个虚函数即可。

private class Access : DBAccess
        
...{
            
public Access(DBType type)
                : 
base(type)
            
...{
            }


            
protected override void InitConn(string strServer, string strDataBase, string strUser, string strPwd)
            
...{
                
string strConn = "Provider = ";
                
switch (strDataBase.Substring(strDataBase.LastIndexOf('.'+ 1).ToLower())
                
...{
                    
case "mdb":     // 2000, 2003
                        strConn += "Microsoft.Jet.OleDb.4.0;";
                        
break;

                    
case "accdb":   // 2007
                        strConn += "Microsoft.ACE.OLEDB.12.0;";
                        
break;

                    
default:
                        
throw (new Exception("Unknown Access Version."));
                    
//break;
                }

                strConn 
+= CON_strDataBase + " = " + strDataBase;
                
//strConn += CON_strUser + " = " + strUser;
                
//strConn += CON_strPwd + " = " + strPwd;
                base.m_oConn = new OleDbConnection(strConn);
            }


            
protected override DbCommand GetCmd(string strCmd)
            
...{
                
return new OleDbCommand(strCmd, (OleDbConnection)base.m_oConn);
            }


            
protected override DbDataAdapter DbAdp
            
...{
                
get ...return new OleDbDataAdapter(); }
            }


            
public override DataTable Tables
            
...{
                
get
                
...{
                    
return ((OleDbConnection)base.m_oConn).GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] ...nullnullnull"Table" });
                }

            }


            
public override DataTable GetColumns()
            
...{
                DataTable dt 
= new DataTable();
                
foreach (DataRow row in this.Tables.Rows)
                
...{
                    dt.Merge(
this.GetColumns(row["TABLE_NAME"].ToString()));
                }

                
return dt;
            }


            
public override DataTable GetColumns(string strTable)
            
...{
                
return ((OleDbConnection)base.m_oConn).GetOleDbSchemaTable(OleDbSchemaGuid.Columns, new object[] ...nullnull, strTable, null });
            }

        }


        
private class SQL : DBAccess
        
...{
            
public SQL(DBType type)
                : 
base(type)
            
...{
            }


            
protected override void InitConn(string strServer, string strDataBase, string strUser, string strPwd)
            
...{
                
string strConn = CON_strServer + " = " + strServer + ";";
                strConn 
+= CON_strDataBase + " = " + strDataBase + ";";
                strConn 
+= CON_strUser + " = " + strUser + ";";
                strConn 
+= CON_strPwd + " = " + strPwd + ";";
                strConn 
+= CON_strConnTimeOut;
                
base.m_oConn = new SqlConnection(strConn);
            }


            
protected override DbCommand GetCmd(string strCmd)
            
...{
                
return new SqlCommand(strCmd, (SqlConnection)base.m_oConn);
            }


            
protected override DbDataAdapter DbAdp
            
...{
                
get ...return new SqlDataAdapter(); }
            }


            
public override DataTable Tables
            
...{
                
get ...return ((SqlConnection)base.m_oConn).GetSchema("Tables"null); }
            }


            
public override DataTable GetColumns()
            
...{
                
return ((SqlConnection)base.m_oConn).GetSchema("Columns"null);
            }


            
public override DataTable GetColumns(string strTable)
            
...{
                
return ((SqlConnection)base.m_oConn).GetSchema("Columns"new string[] ...nullnull, strTable, null });
            }

        }

 

整个例子的完整代码如下,VS2008下编译测试通过,本人已通过它实现N个项目,欢迎大家评测,谢谢指教

public enum DBType
    
...{
        Access,
        SQL,
        DB2,
        Oracle,
        MySQL
    }


    
public interface IDBAccess
    
...{
        
void Init(string strServer, string strDataBase, string strUser, string strPwd);
        
void Open();
        
void Close();
        
bool TestConn();
        
int RunNoQuery(string strCmd);
        DataTable RunQuery(
string strCmd);
        DBType DBType 
...get;}
        
int GetFiledMax(string strTable, string strField);
        DataTable Tables 
...get; }
        DataTable GetColumns();
        DataTable GetColumns(
string strTable);
    }


    
public static class DBAccessFactory
    
...{
        
public static IDBAccess Create(DBType type)
        
...{
            IDBAccess IRet 
= null;
            
switch (type)
            
...{
                
case DBType.Access:
                    IRet 
= new Access(type);
                    
break;

                
case DBType.SQL:
                    IRet 
= new SQL(type);
                    
break;

                
default:
                    
break;
            }

            
return IRet;
        }


        
private abstract class DBAccess : IDBAccess
        
...{
            
protected DbConnection m_oConn = null;
            
protected const string CON_strServer = "Server";
            
protected const string CON_strDataBase = "Data Source";
            
protected const string CON_strUser = "UID";
            
protected const string CON_strPwd = "PWD";
            
protected const string CON_strConnTimeOut = "Connect Timeout = 2";
            
private DBType m_eDBType = DBType.Access;

            
protected DBAccess(DBType type)
            
...{
                
this.m_eDBType = type;
            }


            
public DBType DBType
            
...{
                
get ...return this.m_eDBType; }
            }


            
public void Init(string strServer, string strDataBase, string strUser, string strPwd)
            
...{
                
this.InitConn(strServer, strDataBase, strUser, strPwd);
            }


            
public void Open()
            
...{
                
if (this.m_oConn != null)
                
...{
                    
this.m_oConn.Open();
                }

            }


            
public int RunNoQuery(string strCmd)
            
...{
                
int iRet = 0;
                
try
                
...{
                    DbCommand oCmd 
= this.GetCmd(strCmd);
                    
if (oCmd != null)
                    
...{
                        iRet 
= oCmd.ExecuteNonQuery();
                    }

                }

                
catch (Exception ex)
                
...{
                    
throw (new Exception(ex.Message));
                }

                
return iRet;
            }


            
public int GetFiledMax(string strTable, string strField)
            
...{
                
int iRet = -1;
                DataTable dt 
= this.RunQuery("Select Max(" + strField + ") From " + strTable);
                
if (dt != null && dt.Rows.Count == 1)
                
...{
                    iRet 
= dt.Rows[0][0is DBNull ? 0 : Convert.ToInt32(dt.Rows[0][0]);
                }

                
return iRet;
            }


            
public DataTable RunQuery(string strCmd)
            
...{
                DataTable dt 
= new DataTable();
                DbDataAdapter adp 
= this.DbAdp;
                adp.SelectCommand 
= this.GetCmd(strCmd);
                adp.Fill(dt);
                
return dt;
            }


            
public void Close()
            
...{
                
if (this.m_oConn != null && this.m_oConn.State == System.Data.ConnectionState.Open)
                
...{
                    
this.m_oConn.Close();
                }

            }


            
public bool TestConn()
            
...{
                
bool bRet = true;
                
try
                
...{
                    
if (this.m_oConn.State != System.Data.ConnectionState.Open)
                    
...{
                        
this.m_oConn.Open();
                    }

                    bRet 
= this.m_oConn.State == System.Data.ConnectionState.Open;
                }

                
catch
                
...{
                    bRet 
= false;
                }

                
this.Close();
                
return bRet;
            }


            
public abstract DataTable Tables ...get; }
            
public abstract DataTable GetColumns();
            
public abstract DataTable GetColumns(string strTable);

            
protected abstract void InitConn(string strServer, string strDataBase, string strUser, string strPwd);
            
protected abstract DbCommand GetCmd(string strCmd);
            
protected abstract DbDataAdapter DbAdp ...get;}
        }


        
Access, SQL#region Access, SQL

        
private class Access : DBAccess
        
...{
            
public Access(DBType type)
                : 
base(type)
            
...{
            }


            
protected override void InitConn(string strServer, string strDataBase, string strUser, string strPwd)
            
...{
                
string strConn = "Provider = ";
                
switch (strDataBase.Substring(strDataBase.LastIndexOf('.'+ 1).ToLower())
                
...{
                    
case "mdb":     // 2000, 2003
                        strConn += "Microsoft.Jet.OleDb.4.0;";
                        
break;

                    
case "accdb":   // 2007
                        strConn += "Microsoft.ACE.OLEDB.12.0;";
                        
break;

                    
default:
                        
throw (new Exception("Unknown Access Version."));
                    
//break;
                }

                strConn 
+= CON_strDataBase + " = " + strDataBase;
                
//strConn += CON_strUser + " = " + strUser;
                
//strConn += CON_strPwd + " = " + strPwd;
                base.m_oConn = new OleDbConnection(strConn);
            }


            
protected override DbCommand GetCmd(string strCmd)
            
...{
                
return new OleDbCommand(strCmd, (OleDbConnection)base.m_oConn);
            }


            
protected override DbDataAdapter DbAdp
            
...{
                
get ...return new OleDbDataAdapter(); }
            }


            
public override DataTable Tables
            
...{
                
get
                
...{
                    
return ((OleDbConnection)base.m_oConn).GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] ...nullnullnull"Table" });
                }

            }


            
public override DataTable GetColumns()
            
...{
                DataTable dt 
= new DataTable();
                
foreach (DataRow row in this.Tables.Rows)
                
...{
                    dt.Merge(
this.GetColumns(row["TABLE_NAME"].ToString()));
                }

                
return dt;
            }


            
public override DataTable GetColumns(string strTable)
            
...{
                
return ((OleDbConnection)base.m_oConn).GetOleDbSchemaTable(OleDbSchemaGuid.Columns, new object[] ...nullnull, strTable, null });
            }

        }


        
private class SQL : DBAccess
        
...{
            
public SQL(DBType type)
                : 
base(type)
            
...{
            }


            
protected override void InitConn(string strServer, string strDataBase, string strUser, string strPwd)
            
...{
                
string strConn = CON_strServer + " = " + strServer + ";";
                strConn 
+= CON_strDataBase + " = " + strDataBase + ";";
                strConn 
+= CON_strUser + " = " + strUser + ";";
                strConn 
+= CON_strPwd + " = " + strPwd + ";";
                strConn 
+= CON_strConnTimeOut;
                
base.m_oConn = new SqlConnection(strConn);
            }


            
protected override DbCommand GetCmd(string strCmd)
            
...{
                
return new SqlCommand(strCmd, (SqlConnection)base.m_oConn);
            }


            
protected override DbDataAdapter DbAdp
            
...{
                
get ...return new SqlDataAdapter(); }
            }


            
public override DataTable Tables
            
...{
                
get ...return ((SqlConnection)base.m_oConn).GetSchema("Tables"null); }
            }


            
public override DataTable GetColumns()
            
...{
                
return ((SqlConnection)base.m_oConn).GetSchema("Columns"null);
            }


            
public override DataTable GetColumns(string strTable)
            
...{
                
return ((SqlConnection)base.m_oConn).GetSchema("Columns"new string[] ...nullnull, strTable, null });
            }

        }


        
#endregion

    }

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

c#下各种数据库操作的封装!(支持ACCESS,SQLSERVER,DB2,ORACLE,MYSQL) 的相关文章

  • 确保 StreamReader 不会挂起等待数据

    下面的代码读取从 tcp 客户端流读取的所有内容 并且在下一次迭代中它将仅位于 Read 上 我假设正在等待数据 我如何确保它不会在没有任何内容可供读取时返回 我是否必须设置低超时 并在失败时响应异常 或者有更好的办法吗 TcpClient
  • 如何创建包含 IPv4 地址的文本框? [复制]

    这个问题在这里已经有答案了 如何制作一个这样的文本框 我想所有的用户都见过这个并且知道它的功能 您可以使用带有 Mask 的 MaskedTestBox000 000 000 000 欲了解更多信息 请参阅文档 http msdn micr
  • 回发后刷新时提示确认表单重新提交。我做错了什么?

    我有一个以空白 默认状态启动的仪表板 我让用户能够将保存的状态加载到仪表板中 当他们单击 应用 按钮时 我运行以下代码 function CloseAndSave var radUpload find radUpload1ID var in
  • 如何使用 LINQ2SQL 连接两个不同上下文的表?

    我的应用程序中有 2 个数据上下文 不同的数据库 并且需要能够通过上下文 B 中的表的右连接来查询上下文 A 中的表 我该如何在 LINQ2SQL 中执行此操作 Why 我们正在使用 SaaS 产品来跟踪我们的时间 项目等 并希望向该产品发
  • 在 C 中初始化变量

    我知道有时如果你不初始化int 如果打印整数 您将得到一个随机数 但将所有内容初始化为零似乎有点愚蠢 我问这个问题是因为我正在评论我的 C 项目 而且我对缩进非常直接 并且它可以完全编译 90 90 谢谢 Stackoverflow 但我想
  • 在 Visual Studio 2010 中从 Fortran 调用 C++ 函数

    我想从 Fortran 调用 C 函数 为此 我在 Visual Studio 2010 中创建了一个 FORTRAN 项目 之后 我将一个 Cpp 项目添加到该 FORTRAN 项目中 当我要构建程序时出现以下错误 Error 1 unr
  • qdbusxml2cpp 未知类型

    在使用 qdbusxml2cpp 程序将以下 xml 转换为 Qt 类时 我收到此错误 qdbusxml2cpp c ObjectManager a ObjectManager ObjectManager cpp xml object ma
  • 为什么调用非 const 成员函数而不是 const 成员函数?

    为了我的目的 我尝试包装一些类似于 Qt 共享数据指针的东西 经过测试 我发现当应该调用 const 函数时 会选择它的非 const 版本 我正在使用 C 0x 选项进行编译 这是一个最小的代码 struct Data int x con
  • 在一个平台上,对于所有数据类型,所有数据指针的大小是否相同? [复制]

    这个问题在这里已经有答案了 Are char int long 甚至long long 大小相同 在给定平台上 不能保证它们的大小相同 尽管在我有使用经验的平台上它们通常是相同的 C 2011 在线草稿 http www open std
  • 如何检测表单的任何控件的变化?

    如何检测 C 中表单的任何控件的更改 由于我在一个表单上有许多控件 并且如果表单中的任何控件值发生更改 我需要禁用按钮 我正在寻找一些内置函数 事件处理程序 属性 并且不想为此创建自定义函数 不 我不知道任何时候都会触发任何事件any控制表
  • 如何在 32 位或 64 位配置中以编程方式运行任何 CPU .NET 可执行文件?

    我有一个可在 32 位和 64 位处理器上运行的 C 应用程序 我试图枚举给定系统上所有进程的模块 当尝试从 64 位应用程序枚举 32 位进程模块时 这会出现问题 Windows 或 NET 禁止它 我认为如果我可以从应用程序内部重新启动
  • C#:帮助理解 UML 类图中的 <>

    我目前正在做一个项目 我们必须从 UML 图编写代码 我了解 UML 类图的剖析 但我无法理解什么 lt
  • C# 中的合并运算符?

    我想我记得看到过类似的东西 三元运算符 http msdn microsoft com en us library ty67wk28 28VS 80 29 aspx在 C 中 它只有两部分 如果变量值不为空 则返回变量值 如果为空 则返回默
  • 外键与独立关系 - Entity Framework 5 有改进吗?

    我读过了several http www ladislavmrnka com 2011 05 foreign key vs independent associations in ef 4 文章和问题 https stackoverflow
  • AES 128 CBC 蒙特卡罗测试

    我正在 AES 128 CBC 上执行 MCT 如中所述http csrc nist gov groups STM cavp documents aes AESAVS pdf http csrc nist gov groups STM ca
  • “接口”类似于 boost::bind 的语义

    我希望能够将 Java 的接口语义与 C 结合起来 起初 我用过boost signal为给定事件回调显式注册的成员函数 这非常有效 但后来我发现一些函数回调池是相关的 因此将它们抽象出来并立即注册所有实例的相关回调是有意义的 但我了解到的
  • 如何设置 log4net 每天将我的文件记录到不同的文件夹中?

    我想将每天的所有日志保存在名为 YYYYMMdd 的文件夹中 log4net 应该根据系统日期时间处理创建新文件夹 我如何设置它 我想将一天中的所有日志保存到 n 个 1MB 的文件中 我不想重写旧文件 但想真正拥有一天中的所有日志 我该如
  • 我的班级应该订阅自己的公共活动吗?

    我正在使用 C 3 0 遵循标准事件模式我有 public event EventHandler
  • 使用 .NET Process.Start 运行时挂起进程 - 出了什么问题?

    我在 svn exe 周围编写了一个快速而肮脏的包装器来检索一些内容并对其执行某些操作 但对于某些输入 它偶尔会重复挂起并且无法完成 例如 一个调用是 svn list svn list http myserver 84 svn Docum
  • 从列表中选择项目以求和

    我有一个包含数值的项目列表 我需要使用这些项目求和 我需要你的帮助来构建这样的算法 下面是一个用 C 编写的示例 描述了我的问题 int sum 21 List

随机推荐

  • LVGL 获取光标坐标位置

    为了方便获取物理按键输入的坐标 在仿真时直接开启打印坐标显示 获取自己想要的坐标 核心代码主要接口 indev proc press 打印光标位置 注意要先使能打印开关 LV LOG WARN pressed at x d y d proc
  • HTTP:断点续传原理图文分析

    起源 以前 用户不能使用现在这种高速的带宽访问互联网 当时 下载一个尺寸稍大的图片或文件就已经很吃力了 如果下载过程中遇到网络中断的情况 那就必须重头开始 一 获取部分内容 在HTTP 1 1中 为了解决上述问题 需要一种可恢复的机制 所谓
  • C++ Web服务器 - 用户登录(三)

    newobj跨平台开发框架 https github com Liuccysdgg newobj 本片着重介绍 MYSQL连接池 HTTP静态文件响应 部分JS等 效果演示 一 MYSQL连接池 如果每次业务请求进来时去创建mysql连接并
  • Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime问题解决

    Node Sass does not yet support your current environment Windows 64 bit with Unsupported runtime问题解决 运行原先vue程序时 npm run d
  • Typescript、VUE3的相关介绍

    一 Typescript 1 TypeScript 的由来 TypeScript 是由微软开发的一款开源的编程语言 TypeScript 是 Javascript 的超集 遵循最新的 ES6 ES5 规范 TypeScript 扩展了 Ja
  • 动态规划问题——最长上升子序列(LIS)(一)

    原文转载自我的博客benym cn 推荐链接 动态规划问题 最长上升子序列 LIS 二 动态规划问题 最长上升子序列 LIS 三 如 求 2 7 1 5 6 4 3 8 9 的最长上升子序列 我们定义d i i 1 n 来表示前i个数以A
  • chatgpt赋能Python-python2_7如何安装

    Python 2 7如何安装 Python 2 7是一个广泛使用的Python版本 其可以在Windows和Linux上安装 本文将介绍Python 2 7如何安装 并提供相关步骤和指南 下载Python 2 7 首先 您需要下载Pytho
  • Python for循环嵌套

    视频版教程 Python3零基础7天入门实战视频教程 在有复杂应用的时候 我们可以通过for循环的嵌套来实现 比如打印二维的行列 这里先学习下range 方法 获取一个数字序列 案例 range stop 返回0到stop 1的数字序列 f
  • SQL 通配符

    在 SQL 中 通配符与 SQL LIKE 操作符一起使用 SQL 通配符用于搜索表中的数据 在 SQL 中 可使用以下通配符 通配符 描述 替代 0 个或多个字符 替代一个字符 charlist 字符列中的任何单一字符 charlist
  • Angular项目配置本地https访问

    Angular项目配置本地https访问 首先 先创建一个项目 d work learn ng new angular https 然后cd到刚生成的项目的根目录 建立一个cert目录 用于存放我们的密钥证书等文件 cd angular h
  • 转载---贪心算法

    转载博主 1 贪心算法简介 1 1 基本定义 在贪婪算法 greedy method 中 我们要逐步构造一个最优解 每一步 我们都在一定的标准下 做出一个最优决策 做出决策所依据的标准称为贪心准则 greedy criterion 贪心算法
  • python语法-类型注解

    python语法 类型注解 类型注解 在代码中涉及数据交互的地方 提供数据类型的注解 显式说明 主要功能 帮助第三方IDE工具 如pycharm 对代码进行类型推断 协助做代码提示 帮助开发者自身对变量进行类型注释 支持 变量的类型注解 函
  • 如何安装wsl以及安装时遇到的一些问题

    首先我安装wsl是参考这篇文章 Windows安装WSL详解 讲得挺具体 如果安装过程一切顺利就可以跳过下面的内容了 wsl在终端安装遇到的问题 当我在终端输入wsl install 返回了一列数据 但显然不是安装成功 于是我输入wsl i
  • document onload和window onload的区别?

    答 Document onload 是在结构和样式加载完成才执行的JS Window onload 不仅仅要在结构和样式加载完 还要执行完所有的样式 图片这些资源文件 完全加载完才会触发Window onload事件
  • Oracle SQL查询之Like使用正则表达式

    select from si0001 temp a where regexp like a xm a z A Z 查询xm字段带有英文的数据
  • 2019年第十届蓝桥杯国赛B组试题G-排列数-next_permutation枚举,模拟

    在一个排列中 一个折点是指排列中的一个元素 它同时小于两边的元素 或者同时大于两边的元素 对于一个 1 n 的排列 如果可以将这个排列中包含 t个折点 则它称为一个 t 1 单调序列 例如 排列 1 4 2 3 是一个 3 单调序列 其中
  • Mapreduce学习基础

    一 Mapreduce的基础 1 1 为什么要学习Mapreduce 1 单机资源受限 比如CPU 磁盘 2 分布式计算的程序的复杂度特别高 难度大 mapreduce就是解决以上问题的 1 利用集群的所有cpu 所有内存 所有磁盘 2 m
  • 【TCP/IP】第四章 IP协议

    4 1 即网际协议 TCP IP的心脏是互联网层 这一层主要是由IP Internet Protocol 和ICMP Internet Control Message Protocol 两个协议组成 IP相当于OSI参考模型的第3层 IP
  • 06-TensorFlow 自制数据集

    1 数据文件介绍 数据集下载 https download csdn net download qq 41865229 85254826 训练集60000张数字图片 测试集10000张图片 都是黑底白字的灰度图 每张图有28行28列个像素点
  • c#下各种数据库操作的封装!(支持ACCESS,SQLSERVER,DB2,ORACLE,MYSQL)

    首先定义数据库操作的标准接口IDBAccess 定义接口的基本功能 通过基本的接口设置 完成数据访问的统一抽象 public interface IDBAccess void Init string strServer string str