数据库操作笔记

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

 

StudentNumStudentNameAge
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);
        }

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值