我自己写的简单的OracleHelp
<?xml version="1.0" encoding="utf-8" ?> <configuration> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" /> </startup> <connectionStrings> <add name="connStr" connectionString="data source=192.168.97.60/orcl;User Id=szpt;Password=szpt;"/> </connectionStrings> </configuration>
public class SqlHelp { public static string connstr = ConfigurationManager.ConnectionStrings["connStr"].ConnectionString; /// <summary> /// 返回受影响的行,进行增删改操作(带参数) /// </summary> /// <param name="sql"></param> /// <param name="parameters"></param> /// <returns></returns> public static int ExecuteNonQuery(string sql,params OracleParameter[] parameters) { using(OracleConnection conn=new OracleConnection(connstr)) { conn.Open(); using(OracleCommand cmd=new OracleCommand()) { cmd.Connection = conn; cmd.CommandText = sql; cmd.Parameters.AddRange(parameters); return cmd.ExecuteNonQuery(); } } } /// <summary> /// 返回只有一行一列的数据 /// </summary> /// <param name="sql"></param> /// <param name="parameters"></param> /// <returns></returns> public static object ExecuteScalar(string sql, params OracleParameter[] parameters) { using(OracleConnection conn=new OracleConnection(connstr)) { conn.Open(); using(OracleCommand cmd=new OracleCommand()) { cmd.Connection = conn; cmd.CommandText = sql; cmd.Parameters.AddRange(parameters); return cmd.ExecuteScalar(); } } } /// <summary> /// 返回查询的第一个表 /// </summary> /// <param name="sql"></param> /// <param name="parameters"></param> /// <returns></returns> public static DataTable ExecuteDataTable(string sql, params OracleParameter[] parameters) { using (OracleConnection conn = new OracleConnection(connstr)) { conn.Open(); using(OracleCommand cmd=new OracleCommand()) { cmd.Connection = conn; cmd.CommandText = sql; cmd.Parameters.AddRange(parameters); OracleDataAdapter ada = new OracleDataAdapter(cmd); DataSet ds = new DataSet(); ada.Fill(ds); return ds.Tables[0]; } } } /// <summary> /// 获取数据,其数据是存储在服务端的 /// </summary> /// <param name="sql"></param> /// <param name="parameters"></param> /// <returns></returns> public static OracleDataReader ExecuteDataReader(string sql, params OracleParameter[] parameters) { using (OracleConnection conn = new OracleConnection(connstr)) { conn.Open(); using(OracleCommand cmd=new OracleCommand()) { cmd.Connection = conn; cmd.CommandText = sql; cmd.Parameters.AddRange(parameters); return cmd.ExecuteReader(); } } } }
这里说两点注意的地方1:在写配置文件以及调用配置文件的步骤:(1)项目根目录添加一个“应用程序配置文件”,名字App.config,如果已有此步省略
(2)App.config加节点(如:connectionStrings),给add起一个name(如:connStr)
(3)项目添加对System.configuration的引用(理解为添加开发包。System.Data就是ADO.Net的开发包)
(4)就能使用System.configuration里的ConfigurationManager类 如:public static string connstr = ConfigurationManager.ConnectionStrings["connStr"].ConnectionString;
2:当用conn.Open()已经打开数据库大时候,在下面用Cmd是必须要写cmd.Connection = conn;使cmd也连接数据库,oracle数据库是必须要写的,至于sql server以及其他数据库需不需要我还没有试验过,暂时不知道。
3:就是在调用OracleHelp的带参数方法时,要用:不能用 @ 如:DataTable dt = SqlHelp.ExecuteDataTable("SELECT ID FROM SZPT WHERE age=:age AND PLACE=:place",new OracleParameter(":age","4"),new OracleParameter(":place","科学大道"));
:age不能写成@age 要注意:在 new OracleParameter() 中,指定的ParameterName 只需要包含参数的字符部分,无需保含前缀,如:冒号。 简单点:@ 改成 :
SqlClient参数表达式:@ParameterName
OracleClient参数表达式::ParameterName