Access数据库操作
public static class AccessHelper
{
public static string strConn = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=testDB.accdb";
//打开数据连接
public static OleDbConnection OpenConnection()
{
OleDbConnection conn = new OleDbConnection(strConn);
try
{
conn.Open();
}
catch(Exception ex)
{
Console.WriteLine("打开数据库异常:{0}",ex.Message);
}
return conn;
}
//执行SQL语句,并返回受影响的行数
public static int ExecuteNonQuery(string strCmd)
{
int rows = 0;
OleDbConnection conn = OpenConnection();
if(conn.State == System.Data.ConnectionState.Open)
{
try
{
OleDbCommand comm = new OleDbCommand(strCmd, conn);
rows = comm.ExecuteNonQuery();//返回受影响的行数
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
finally
{
conn.Close();
}
}
return rows;
}
//执行SQL语句,并返回受影响的行数
//传递参数
public static int ExecuteNonQuery(string strCmd, OleDbParameter[] values)
{
int rows = 0;
OleDbConnection conn = OpenConnection();
if(conn.State == System.Data.ConnectionState.Open)
{
try
{
OleDbCommand cmd = new OleDbCommand(strCmd, conn);
cmd.Parameters.AddRange(values);
rows = cmd.ExecuteNonQuery();
}
catch(Exception ex)
{
Console.WriteLine(ex.Message);
}
finally
{
conn.Close();
}
}
return rows;
}
//获取数据表
public static DataTable GetDataTable(string strCmd)
{
DataTable table = new DataTable();
OleDbConnection conn = OpenConnection();
if(conn.State == ConnectionState.Open)
{
try
{
OleDbDataAdapter adapter = new OleDbDataAdapter(strCmd, conn);
adapter.Fill(table);
}
catch (Exception ex)
{
Console.WriteLine("GetDataTable:" + ex.Message);
}
finally
{
conn.Close();
}
}
return table;
}
}
Excel操作
public static class ExcelHelper
{
private static string fileName = AppDomain.CurrentDomain.SetupInformation.ApplicationBase + @"ExcelDB.xlsx";
public static OleDbConnection OpenConnection()
{
string strConn = "";
string fileType = System.IO.Path.GetExtension(fileName);
if (string.IsNullOrEmpty(fileType))
return null;
if (fileType == ".xls")
{
strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName + ";" + ";Extended Properties=\"Excel 8.0;HDR=YES;IMEX=2\"";
}
else
{
//strConn = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + fileName + ";Extended Properties='Excel 12.0;HDR=YES;IMEX=2'";
//strConn = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + fileName + ";Extended Properties='Excel 12.0;HDR=YES;IMEX=10'";
//HDR=YES 表示第一行为表头
//不写IMEX 可以插入数据 不然插入不了
strConn = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + fileName + ";Extended Properties='Excel 12.0;HDR=YES'";
}
OleDbConnection conn = new OleDbConnection(strConn);
conn.Open();
return conn;
}
//执行SQL语句,并返回受影响的行数
public static int ExecuteNonQuery(string strCmd)
{
int rows = 0;
OleDbConnection conn = OpenConnection();
if (conn.State == System.Data.ConnectionState.Open)
{
try
{
OleDbCommand comm = new OleDbCommand(strCmd, conn);
rows = comm.ExecuteNonQuery();//返回受影响的行数
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
finally
{
conn.Close();
}
}
return rows;
}
//执行SQL语句,并返回受影响的行数
//传递参数
public static int ExecuteNonQuery(string strCmd, OleDbParameter[] values)
{
int rows = 0;
OleDbConnection conn = OpenConnection();
if (conn.State == System.Data.ConnectionState.Open)
{
try
{
OleDbCommand cmd = new OleDbCommand(strCmd, conn);
cmd.Parameters.AddRange(values);
rows = cmd.ExecuteNonQuery();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
finally
{
conn.Close();
}
}
return rows;
}
//获取数据表
public static DataTable GetDataTable(string strCmd)
{
DataTable table = new DataTable();
OleDbConnection conn = OpenConnection();
if (conn.State == ConnectionState.Open)
{
try
{
OleDbDataAdapter adapter = new OleDbDataAdapter(strCmd, conn);
adapter.Fill(table);
}
catch (Exception ex)
{
Console.WriteLine("GetDataTable:" + ex.Message);
}
finally
{
conn.Close();
}
}
return table;
}
}
/*
使用SQL语句是需要注意表名如何写 例如:[sheet1$]
Excel的表头可以是中文 表名也可以是中文
原来Excel不支持删除,DELETE FROM sheet1报错“该ISAM不支持在链接表中删除数据”。
因为Excel工作表中的行与真正的关系型数据库的行是有些不一样的,所以如果通过编程来访问Excel工作表的数据,那么检索,插入,更新应该是没有问题的,但要是删除的话,就会有一些限制。
删除Excel数据时,受到的限制要比从关系数据源中删除数据时更多。在关系数据库中,“行”除了表示一条“记录”外没有其他意义;但在Excel工作表中却不同。
可以删除字段(单元格)中的值,但不能:
1、一次删除一整条记录,否则将出现以下错误信息:DeletingdatainalinkedtableisnotsupportedbythisISAM.只能通过分别清空各个字段的内容来删除一条记录。
2、删除包含Excel公式的单元格中的值,否则将出现以下错误信息:Operationisnotallowedinthiscontext.
3、虽然电子表格中已被删除的数据原来所在的行现在是空行,但无法将其删除,而且记录集将继续显示对应于这些空行的空记录。
针对这个问题,通常简单的做法就是清空字段的值,类似这样的写法:UPDATE sheet1 SET NAME = NULL, DeptName= NULL WHERE DeptId = 1;
当然,你要知道的是,这一行并没有真正删除掉,所以通常在select的时候要进行一定的筛选,例如:SELECT * FROM sheet1$ WHERE DeptId IS NOT NULL;
备注:
1、中转删除法(物理删除)
通过MSSQL的一个语法将EXCEL数据导入到一个MSSQL中一个表里,然后直接操作MSSQL删除表中的某些你要删除的行。
再将原EXCEL文件删除或改名,然后从MSSQL的那个表中将数据导出为原EXCEL文件名。
*/
SQL Server操作
public static class SQLHelper
{
public static SqlConnection OpenConnection()
{
string strConn = "Data Source=localhost;Initial Catalog=testDB;User Id=sa;Password=123";
SqlConnection conn = new SqlConnection(strConn);
conn.Open();
return conn;
}
//执行SQL语句,并返回受影响的行数
public static int ExecuteNonQuery(string strCmd)
{
int rows = 0;
SqlConnection conn = OpenConnection();
if (conn.State == System.Data.ConnectionState.Open)
{
try
{
SqlCommand comm = new SqlCommand(strCmd, conn);
rows = comm.ExecuteNonQuery();//返回受影响的行数
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
finally
{
conn.Close();
}
}
return rows;
}
//执行SQL语句,并返回受影响的行数
//传递参数
public static int ExecuteNonQuery(string strCmd, SqlParameter[] values)
{
int rows = 0;
SqlConnection conn = OpenConnection();
if (conn.State == System.Data.ConnectionState.Open)
{
try
{
SqlCommand cmd = new SqlCommand(strCmd, conn);
cmd.Parameters.AddRange(values);
rows = cmd.ExecuteNonQuery();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
finally
{
conn.Close();
}
}
return rows;
}
//获取数据表
public static DataTable GetDataTable(string strCmd)
{
DataTable table = new DataTable();
SqlConnection conn = OpenConnection();
if (conn.State == ConnectionState.Open)
{
try
{
SqlDataAdapter adapter = new SqlDataAdapter(strCmd, conn);
adapter.Fill(table);
}
catch (Exception ex)
{
Console.WriteLine("GetDataTable:" + ex.Message);
}
finally
{
conn.Close();
}
}
return table;
}
//由于测试 以下代码未做条件判断和异常捕获 只写了主要的逻辑 正式写的时候需要注意
//执行查询,并返回由查询返回的结果集中的第一行的第一列。 其他列或行将被忽略。
public static object ExecuteScalar(string strCmd)
{
SqlConnection conn = OpenConnection();
SqlCommand comm = new SqlCommand(strCmd, conn);
object obj = comm.ExecuteScalar();
conn.Close();
return obj;
}
}
SQL 语句
数据库testDB 数据表tb_Student
StudentNum | StudentName | Age |
---|---|---|
1001 | 小明 | 17 |
1002 | 小红 | 18 |
--增加
insert into testDB.dbo.tb_Student values ('1001','小明',18)
--删除
delete from testDB.dbo.tb_Student where StudentNum = '1001'
--修改
update testDB.dbo.tb_Student set StudentName='小明2',Age=19 where StudentNum = '1001'
--查询
select * from testDB.dbo.tb_Student
创建存储过程和通sql执行测试
--创建存储过程
--注意 output是用来输出变量的
create proc proc_test
@stuNum nvarchar(50),
@rowCount int output
as
begin
select * from tb_Student where StudentNum = @stuNum
set @rowCount = @@ROWCOUNT
end
--执行调用存储过程(进行传参 并获取输出数据)(需要添加output关键字)
declare @rountNum nvarchar(50)
exec proc_test '1001',@rountNum output
select @rountNum
c#执行存储过程
private void btnProcedure_Click(object sender, RoutedEventArgs e)
{
string strConn = "Server=localhost;Database=testDB;uid=sa;pwd=123";
SqlConnection conn = new SqlConnection(strConn);
conn.Open();
SqlCommand comm = new SqlCommand("proc_test", conn);//存储过程名称
comm.Parameters.Add("@stuNum", SqlDbType.Int);
comm.Parameters["@stuNum"].Value = "1001";
comm.Parameters["@stuNum"].Direction = ParameterDirection.Input;//输入参数
comm.Parameters.Add("@rowCount", SqlDbType.Int);
//comm.Parameters["@rowCount"].Value = 1;//输出参数可以不设置
comm.Parameters["@rowCount"].Direction = ParameterDirection.Output;//输出参数
comm.CommandType = CommandType.StoredProcedure;//存储过程
//获取DataTable获取数据
DataTable table = new DataTable();
SqlDataAdapter adapter = new SqlDataAdapter(comm);
adapter.Fill(table);
for (int i = 0; i < table.Rows.Count; i++)
{
DataRow row = table.Rows[i];
string stuName = (string)row["StudentName"];
string stuNum = (string)row["StudentNum"];
int age = (int)row["Age"];
Console.WriteLine("stuName:{0},stuNum:{1},age:{2}", stuName,stuNum,age);
}
//获取输出参数
int num = (int)comm.Parameters["@rowCount"].Value;
Console.WriteLine("num:{0}", num);
}