惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

D
Darknet – Hacking Tools, Hacker News & Cyber Security
V
Vulnerabilities – Threatpost
Cloudbric
Cloudbric
G
GRAHAM CLULEY
S
Securelist
Schneier on Security
Schneier on Security
Help Net Security
Help Net Security
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
Project Zero
Project Zero
Spread Privacy
Spread Privacy
P
Privacy International News Feed
C
Cyber Attacks, Cyber Crime and Cyber Security
Cisco Talos Blog
Cisco Talos Blog
T
Tailwind CSS Blog
博客园_首页
有赞技术团队
有赞技术团队
Simon Willison's Weblog
Simon Willison's Weblog
Stack Overflow Blog
Stack Overflow Blog
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
Latest news
Latest news
T
Tor Project blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Attack and Defense Labs
Attack and Defense Labs
www.infosecurity-magazine.com
www.infosecurity-magazine.com
O
OpenAI News
J
Java Code Geeks
T
Tenable Blog
K
Kaspersky official blog
AWS News Blog
AWS News Blog
S
Security @ Cisco Blogs
The GitHub Blog
The GitHub Blog
T
Threatpost
月光博客
月光博客
H
Heimdal Security Blog
Security Latest
Security Latest
The Hacker News
The Hacker News
Y
Y Combinator Blog
A
Arctic Wolf
Apple Machine Learning Research
Apple Machine Learning Research
C
Cisco Blogs
美团技术团队
Microsoft Security Blog
Microsoft Security Blog
Hugging Face - Blog
Hugging Face - Blog
T
The Blog of Author Tim Ferriss
C
CERT Recently Published Vulnerability Notes
D
Docker
Google Online Security Blog
Google Online Security Blog
D
DataBreaches.Net
V
Visual Studio Blog
H
Help Net Security

博客园 - KenBlove

错误代码:0x800706BE 解决方法 泛微OA服务器更改IP地址后EMobile出现“调用远端服务器接口时发生错误(122)”的提示 HTTP 错误 404 - 文件或目录未找到 HTTP 错误 401.2 - 未经授权:访问由于服务器配置被拒绝。 优雅还不够,简洁才高效!——用NValidator一句话搞定客户端检测 MyXls初级教程 纯CSS实现底部固定漂浮导航 Access和SQL server开启表间关系,并实现更新或删除母表数据自动更新或删除子表数据 来自微软关于异常处理的17条军规 一个简单的拖动层(兼容IE,FF) SQL Server Profiler过滤本机信息的办法 "The state information is invalid for this page and might be corrupted"错误的一个解决办法 SQL回滚Transaction来调试SQL语句 SQL找出和删除一个表的重复记录 SQL常用判断检测语句 SQL把ID相同的记录合并成同一条记录 从丑陋到优雅,让代码越变越美续集之服务器端数据校验 关于FireFox记住密码后出现的bug 关于Iframe在IE6下不显示的bug 从丑陋到优雅,让代码越变越美(客户端检测方法思考)
一个仿PetShop的通用DBHelper类
KenBlove · 2009-07-01 · via 博客园 - KenBlove

今天参考PetShop的SqlHelper写了个更通用的DBHelper,兼容大部分DB.感觉对于小型开发来说,使用这样的通用类,更换DB会方便.奉上代码:

Code
using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Data.Common;
using System.Configuration;namespace MBDone.Core.DBUtility
{
    
public static class DBHelper
    {
        
private static readonly string connStringName = ConfigurationManager.AppSettings["connStringName"].ToString();
        
private static readonly string connString = ConfigurationManager.ConnectionStrings[connStringName].ConnectionString;
        
private static readonly string providerName = ConfigurationManager.ConnectionStrings[connStringName].ProviderName;
        
public static DbProviderFactory provider = DbProviderFactories.GetFactory(providerName);#region Public Mothodspublic static int ExcuteNonQuery(string cmdText, params DbParameter[] cmdParms)
        {
            
return ExcuteNonQuery(null, CommandType.Text, cmdText, cmdParms);
        }
public static int ExcuteNonQuery(CommandType cmdType, string cmdText, params DbParameter[] cmdParms)
        {
            
return ExcuteNonQuery(null, cmdType, cmdText, cmdParms);
        }
public static int ExcuteNonQuery(DbTransaction trans, CommandType cmdType, string cmdText, params DbParameter[] cmdParms)
        {
            
using (DbConnection conn = provider.CreateConnection())
            {
                
using (DbCommand cmd = provider.CreateCommand())
                {
                    PrepareCommand(cmd, conn, trans, cmdType, cmdText, cmdParms);
                    
return cmd.ExecuteNonQuery();
                }
            }
        }
public static DbDataReader ExecuteReader(string cmdText, params DbParameter[] cmdParms)
        {
            
return ExecuteReader(null, CommandType.Text, cmdText, cmdParms);
        }
public static DbDataReader ExecuteReader(CommandType cmdType, string cmdText, params DbParameter[] cmdParms)
        {
            
return ExecuteReader(null, cmdType, cmdText, cmdParms);
        }
public static DbDataReader ExecuteReader(DbTransaction trans, CommandType cmdType, string cmdText, params DbParameter[] cmdParms)
        {
            DbConnection conn 
= provider.CreateConnection();
            DbCommand cmd 
= provider.CreateCommand();try
            {
                PrepareCommand(cmd, conn, trans, cmdType, cmdText, cmdParms);
                
return cmd.ExecuteReader(CommandBehavior.CloseConnection);
            }
            
catch
            {
                conn.Close();
                cmd.Dispose();
                
throw;
            }
        }
public static object ExecuteScalar(string cmdText, params DbParameter[] cmdParms)
        {
            
return ExecuteScalar(null, CommandType.Text, cmdText, cmdParms);
        }
public static object ExecuteScalar(CommandType cmdType, string cmdText, params DbParameter[] cmdParms)
        {
            
return ExecuteScalar(null, cmdType, cmdText, cmdParms);
        }
public static object ExecuteScalar(DbTransaction trans, CommandType cmdType, string cmdText, params DbParameter[] cmdParms)
        {
            
using (DbConnection conn = provider.CreateConnection())
            {
                
using (DbCommand cmd = provider.CreateCommand())
                {
                    PrepareCommand(cmd, conn, trans, cmdType, cmdText, cmdParms);
                    
return cmd.ExecuteScalar();
                }
            }
        }
#endregion#region Private Methodsprivate static void PrepareCommand(DbCommand cmd, DbConnection conn, DbTransaction trans, CommandType cmdType, string cmdText, DbParameter[] cmdParms)
        {
            conn.ConnectionString 
= connString;
            
if (conn.State != ConnectionState.Open)
                conn.Open();

            cmd.Connection 

= conn;
            cmd.CommandText 
= cmdText;if (trans != null)
                cmd.Transaction 
= trans;

            cmd.CommandType 

= cmdType;if (cmdParms != null)
            {
                
foreach (DbParameter parm in cmdParms)
                    cmd.Parameters.Add(parm);
            }
        }
#endregion
    }
}

使用如下:

Code
string sql1 = "Delete From [User] Where [Id]=@Id";
DbParameter param 
= DBHelper.provider.CreateParameter();
param.ParameterName 
= "@Id";
param.Value 
= 3;
DbParameter[] ps 
= { param };
int count = DBHelper.ExcuteNonQuery(sql2, ps);string sql2 = "SELECT TOP 100 [Id],[Name] FROM [User]";
DbDataReader dr 
= DBHelper.ExecuteReader(sql2, null);
while (dr.Read())
{
    
string name = dr[1].ToString();
}
dr.Close();

Web.config配置使用哪一种DB:(由上而下分别是Access,SQL server,SQLite)

Code
<appSettings>
    
<add key="connStringName" value="defaultConnectionString1"/>
</appSettings>
<connectionStrings>
    
<add name="defaultConnectionString1" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\UserDB.mdb;Jet OLEDB:Database Password=1234567" providerName="System.Data.OleDb"/>
    
<add name="defaultConnectionString2" connectionString="Data Source=10.152.86.42;Initial Catalog=UserDB;Persist Security Info=False;User ID=sa; pwd = 1234567" providerName="System.Data.SqlClient"/>
    
<add name="defaultConnectionString3" connectionString="Data Source=|DataDirectory|\UserDB.s3db;Version=3;BinaryGUID=False;" providerName="System.Data.SQLite"/>
</connectionStrings>

注意如果使用SQLite除了引用"System.Data.SQLite.DLL"(在 http://sourceforge.net/projects/sqlite-dotnet2 下载 ADO.NET 2.0 Provider。找到下载包中的 System.Data.SQLite.DLL 拷贝到程序 Bin 目录。)

还必须配置DB Provider:

Code
<system.data>
    
<DbProviderFactories>
        
<remove invariant="System.Data.SQLite"/>
        
<add name="SQLite Data Provider" invariant="System.Data.SQLite" description=".Net Framework Data Provider for SQLite" type="System.Data.SQLite.SQLiteFactory, System.Data.SQLite"/>
    
</DbProviderFactories>
</system.data>

否则会报错:

Code
Unable to find the requested .Net Framework Data Provider.  It may not be installed.

注:本文基于WebApp开发而讲述.