C#连接数据库以及增、删、改、查操作

using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace _03.ado.net
{
    class Program
    {
        static void Main(string[] args)
        {
            #region 连接数据库
            ////连接数据库的步骤:
            ////1.创建连接字符串
            ////Data Source=服务器名;
            ////Initial Catalog=数据库名;
            ////Integrated Security=True;声明验证方式
            ////用户名、密码方式
            //string constr = "Data Source=localhost;Initial Catalog=zwt;uid=root;pwd=zwt";
            ////集成式
            ////string constr = "Data Source=localhost;Initial Catalog=zwt;integrated Security=true";

            ////2.创建连接对象
            //using (SqlConnection con = new SqlConnection(constr))
            //{
            //    //测试,打开连接
            //    //3.打开连接(如果打开数据连接没有问题,表示连接成功)
            //    con.Open();
            //    Console.WriteLine("数据库连接成功");
            //    //4.关闭连接,释放资源
            //    con.Close();

            //    //con.Dispose();
            //}
            //Console.WriteLine("断开连接");
            //Console.ReadKey();
            #endregion

            #region 增加数据
            ////连接数据库的步骤:
            ////1.创建连接字符串
            ////Data Source=服务器名;
            ////Initial Catalog=数据库名;
            ////Integrated Security=True;声明验证方式
            ////用户名、密码方式
            //string constr = "Data Source=localhost;Initial Catalog=zwt;uid=root;pwd=zwt";
            ////集成式
            ////string constr = "Data Source=localhost;Initial Catalog=zwt;integrated Security=true";

            ////2.创建连接对象
            //using (SqlConnection con = new SqlConnection(constr))
            //{
            //    //4.编写SQL语句
            //    string sql = "insert into zwt values('Tony',23,'男')";
            //    //5.创建一个执行sql语句的对象(命令对象)sqlcommand
            //    using (SqlCommand cmd = new SqlCommand(sql, con))
            //    {
            //        //6.开始执行SQL语句
            //        //3个命令对象
            //        //cmd.ExecuteNonQuery();方法有一个int型的返回值,表示执行insert、delete、update语句后所影响的行数,
            //        //并且只有执行这3种语句时返回影响的行数,其他语句都返回-1
            //        int r = cmd.ExecuteNonQuery();
            //        //cmd.ExecuteNonQuery();//执行insert、delete、update语句
            //        //cmd.ExecuteScalar();//执行返回单个结果
            //        //cmd.ExecuteReader();//查询出多行、多列结果
            //        //3.打开连接(连接对象最晚打开,最早关闭,节约资源)
            //        con.Open();
            //        Console.WriteLine("已成功插入{0}行数据", r);
            //    }
            //}
            //Console.ReadKey();
            #endregion

            #region 删除数据
            ////1.创建连接字符串
            //string constr = "Data Source=localhost;Initial Catalog=zwt;Integrated Security=True";
            ////2.连接对象
            //using (SqlConnection con = new SqlConnection(constr))
            //{
            //    //3.sql语句
            //    string sql = "delete from zwttable where name=tony";
            //    //4.创建sqlcommand对象
            //    using (SqlCommand cmd = new SqlCommand(sql, con))
            //    {
            //        //5.打开链接
            //        con.Open();
            //        //6.执行
            //        int r = cmd.ExecuteNonQuery();
            //        Console.WriteLine("成功删除了{0}行数据", r);
            //    }
            //}
            //Console.ReadKey();
            #endregion

            #region 修改数据
            ////1.创建连接字符串
            //string constr = "Data Source=localhost;Initial Catalog=zwt;Integrated Security=True";
            ////2.连接对象
            //using (SqlConnection con = new SqlConnection(constr))
            //{
            //    //3.sql语句
            //    string sql = "update zwttable set name=tony,age=26";
            //    //4.创建sqlcommand对象
            //    using (SqlCommand cmd = new SqlCommand(sql, con))
            //    {
            //        //5.打开链接
            //        con.Open();
            //        //6.执行
            //        int r = cmd.ExecuteNonQuery();
            //        Console.WriteLine("成功更新了{0}行数据", r);
            //    }
            //}
            //Console.ReadKey();
            #endregion

            #region 查询一条数据
            ////1.创建连接字符串
            //string constr = "Data Source=localhost;Initial Catalog=zwt;Integrated Security=True";
            ////2.连接对象
            //using (SqlConnection con = new SqlConnection(constr))
            //{
            //    //3.sql语句
            //    string sql = "select count(*) from zwttable";
            //    //4.创建sqlcommand对象
            //    using (SqlCommand cmd = new SqlCommand(sql, con))
            //    {
            //        //5.打开链接
            //        con.Open();
            //        //6.执行
            //        //sql语句执行时如果是聚合函数,ExecuteScalar()的返回不可能为null,如果不是聚合函数则需要判断是否为null
            //        //object count = (int)cmd.ExecuteScalar();
            //        //避免异常
            //        object count = Convert.ToInt32(cmd.ExecuteScalar());
            //        Console.WriteLine("zwttable表*有{0}条数据", count);
            //    }
            //}
            //Console.ReadKey();
            #endregion

            #region 查询多条数据
            ////1.创建连接字符串
            //string constr = "Data Source=localhost;Initial Catalog=zwt;Integrated Security=True";
            ////2.连接对象
            //using (SqlConnection con = new SqlConnection(constr))
            //{
            //    //3.sql语句
            //    string sql = "select * from zwttable";
            //    //4.创建sqlcommand对象
            //    using (SqlCommand cmd = new SqlCommand(sql, con))
            //    {
            //        //5.打开链接
            //        con.Open();
            //        //通过调用ExecuteReader()方法,将给定的sql语句在服务器端执行
            //        //执行完毕后,服务器端已经查好数据,但数据保存在数据库服务器内存里。并没有返回给应用程序,
            //        //只是返回给应用程序一个reader对象,这个对象就是用来获取数据的对象
            //        using (SqlDataReader reader = cmd.ExecuteReader())
            //        {
            //            //接下来就是要通过reader对象一条一条获取数据
            //            //1.在获取数据前,先判断一下本次执行查询后,是否查到了数据
            //            if(reader.HasRows)//如果有数据为true,否则为false
            //            {
            //                //2.如果有数据,那么接下来就要一条条获取数据
            //                //每次获取数据之前,都要调用reader.Read()方法,向后移动一条数据,如果成功移动到了某条数据
            //                //上,则返回true,否则返回false
            //                while (reader.Read())
            //                {
            //                    //获取当前reader指向的数据
            //                    //reader.FieldCount可以获取当前查询语句查询到的列数
            //                    for (int i = 0; i < reader.FieldCount; i++)
            //                    {
            //                        Console.Write(reader[i]+"    |    ");
            //                    }
            //                    Console.WriteLine();
            //                }
            //            }
            //            else
            //            {
            //                Console.WriteLine("没有查到数据");
            //            }
            //        }
            //    }
            //}
            //Console.ReadKey();
            #endregion
        }
    }
}