MSSQL操作类

简介:
这是我自已常用的MSSQL操作类,个人用着觉得还可以,如果高手有更好的,也可以帖出来供大家分享一下,呵呵!! 
========================================== 
using System; 
using System.Configuration; 
using System.Collections; 
using System.Data; 
using System.Data.SqlClient; 

namespace MyData 

/// <summary> 
/// 通用数据库类MSSQL 
/// </summary> 
public class MSSQL 


public static string ConnStr = @"server=电脑名\SQLEXPRESS(或IP,端口);uid=数据库帐号;pwd=数据库密码;database=数据库名;"; 
//public static string ConnStr = @MyData.Properties.Settings.Default.my_soft_sqlConn; 


//打开数据库链接 
public static SqlConnection Open_Conn(string ConnStr) 

try 

SqlConnection Conn = new SqlConnection(ConnStr + "Connect Timeout=5;"); 
Conn.Open(); 
return Conn; 

catch (Exception Ex) 

throw Ex; 



//关闭数据库链接 
public static void Close_Conn(SqlConnection Conn) 

if (Conn != null) 

Conn.Close(); 
Conn.Dispose(); 

GC.Collect(); 


//运行Sql语句 
public static int Run_SQL(string SQL, string ConnStr) 

SqlConnection Conn = Open_Conn(ConnStr); 
SqlCommand Cmd = Create_Cmd(SQL, Conn); 
try 

int result_count = Cmd.ExecuteNonQuery(); 
Close_Conn(Conn); 
return result_count; 

catch (Exception Ex) 

throw Ex; 



// 生成Command对象 
public static SqlCommand Create_Cmd(string SQL, SqlConnection Conn) 

SqlCommand Cmd = new SqlCommand(SQL, Conn); 
return Cmd; 


// 运行Sql语句返回 DataTable 
public static DataTable Get_DataTable(string SQL, string ConnStr, string Table_name) 

SqlConnection Conn = Open_Conn(ConnStr); 
SqlDataAdapter Da = new SqlDataAdapter(SQL, Conn); 
DataTable dt = new DataTable(Table_name); 
Da.Fill(dt); 
Close_Conn(Conn); 
return dt; 


// 运行Sql语句返回 SqlDataReader对象 
public static SqlDataReader Get_Reader(string SQL, string ConnStr) 

SqlConnection Conn = Open_Conn(ConnStr); 
SqlCommand Cmd = Create_Cmd(SQL, Conn); 
SqlDataReader Dr; 
try 

Dr = Cmd.ExecuteReader(CommandBehavior.Default); 

catch 

throw new Exception(SQL); 

Close_Conn(Conn); 
return Dr; 


// 运行Sql语句返回 SqlDataAdapter对象 
public static SqlDataAdapter Get_Adapter(string SQL, string ConnStr) 

SqlConnection Conn = Open_Conn(ConnStr); 
SqlDataAdapter Da = new SqlDataAdapter(SQL, Conn); 
return Da; 


// 运行Sql语句,返回DataSet对象 
public static DataSet Get_DataSet(string SQL, string ConnStr, DataSet Ds) 

SqlConnection Conn = Open_Conn(ConnStr); 
SqlDataAdapter Da = new SqlDataAdapter(SQL, Conn); 
try 

Da.Fill(Ds); 

catch (Exception Ex) 

throw Ex; 

Close_Conn(Conn); 
return Ds; 


// 运行Sql语句,返回DataSet对象 
public static DataSet Get_DataSet(string SQL, string ConnStr, DataSet Ds, string tablename) 

SqlConnection Conn = Open_Conn(ConnStr); 
SqlDataAdapter Da = new SqlDataAdapter(SQL, Conn); 
try 

Da.Fill(Ds, tablename); 

catch (Exception Ex) 

throw Ex; 

Close_Conn(Conn); 
return Ds; 


// 运行Sql语句,返回DataSet对象,将数据进行了分页 
public static DataSet Get_DataSet(string SQL, string ConnStr, DataSet Ds, int StartIndex, int PageSize, string tablename) 

SqlConnection Conn = Open_Conn(ConnStr); 
SqlDataAdapter Da = new SqlDataAdapter(SQL, Conn); 
try 

Da.Fill(Ds, StartIndex, PageSize, tablename); 

catch (Exception Ex) 

throw Ex; 

Close_Conn(Conn); 
return Ds; 


// 返回Sql语句执行结果的第一行第一列 
public static string Get_Row1_Col1_Value(string SQL, string ConnStr) 

SqlConnection Conn = Open_Conn(ConnStr); 
string result; 
SqlDataReader Dr; 
try 

Dr = Create_Cmd(SQL, Conn).ExecuteReader(); 
if (Dr.Read()) 

result = Dr[0].ToString(); 
Dr.Close(); 

else 

result = ""; 
Dr.Close(); 


catch 

throw new Exception(SQL); 

Close_Conn(Conn); 
return result; 



}

将上面的代码保存为MSSQL.cs类文件,可以用以下代码进行调用 
======================================== 
1、查询 
string SQL = "select * from 表名 where 条件"; 
DataTable dt = MSSQL.Get_DataTable(SQL, MSSQL.ConnStr, "DataTable表名或空"); 

2、添加、修改、删除 
string SQL = "添加、修改、删除 SQL语句"; 

MSSQL.Run_SQL(SQL, MSSQL.ConnStr); 


本文转自夜&枫博客园博客,原文链接:http://www.cnblogs.com/newstart/archive/2012/05/16/2504646.html,如需转载请自行联系原作者


相关文章
|
4天前
|
人工智能 运维 安全
|
2天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
9天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
817 109
|
3天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
415 9
|
3天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。
|
4天前
|
机器学习/深度学习 传感器 算法
Edge Impulse:面向微型机器学习的MLOps平台——论文解读
Edge Impulse 是一个面向微型机器学习(TinyML)的云端MLOps平台,致力于解决嵌入式与边缘设备上机器学习开发的碎片化与异构性难题。它提供端到端工具链,涵盖数据采集、信号处理、模型训练、优化压缩及部署全流程,支持资源受限设备的高效AI实现。平台集成AutoML、量化压缩与跨硬件编译技术,显著提升开发效率与模型性能,广泛应用于物联网、可穿戴设备与边缘智能场景。
186 127