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

推荐订阅源

F
Fortinet All Blogs
Attack and Defense Labs
Attack and Defense Labs
V2EX - 技术
V2EX - 技术
O
OpenAI News
S
Secure Thoughts
H
Heimdal Security Blog
Application and Cybersecurity Blog
Application and Cybersecurity Blog
Schneier on Security
Schneier on Security
H
Hacker News: Front Page
S
Security Affairs
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Vercel News
Vercel News
Microsoft Security Blog
Microsoft Security Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
P
Proofpoint News Feed
The Register - Security
The Register - Security
GbyAI
GbyAI
Cloudbric
Cloudbric
MongoDB | Blog
MongoDB | Blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
K
Kaspersky official blog
Forbes - Security
Forbes - Security
Y
Y Combinator Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
Scott Helme
Scott Helme
Hacker News - Newest:
Hacker News - Newest: "LLM"
The Cloudflare Blog
Recorded Future
Recorded Future
人人都是产品经理
人人都是产品经理
Cyberwarzone
Cyberwarzone
C
CERT Recently Published Vulnerability Notes
Webroot Blog
Webroot Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
L
LangChain Blog
T
Tor Project blog
Microsoft Azure Blog
Microsoft Azure Blog
博客园_首页
Hacker News: Ask HN
Hacker News: Ask HN
Blog — PlanetScale
Blog — PlanetScale
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
B
Blog RSS Feed
N
News and Events Feed by Topic
阮一峰的网络日志
阮一峰的网络日志
I
Intezer
V
V2EX
T
Tailwind CSS Blog
SecWiki News
SecWiki News
NISL@THU
NISL@THU
C
Check Point Blog

博客园 - 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开发而讲述.