c#数据库操作

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

namespace 数据库操作
{
    class Program
    {
        static void Main(string[] args)
        {
            #region 连接数据库
            连接数据库的步骤:
            1.创建连接字符串
            Data Source=服务器名;
            Initial Catalog=数据库名;
            Integrated Security=True;声明验证方式
            用户名、密码方式
            //string constr = "Data Source=localhost;Initial Catalog=Library;User Id=sa;Password=123456";
            集成式
            //string constr = "Data Source=localhost;Initial Catalog=Library;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

            //自己测试
            #region
            string constr = "Data Source = .;Initial Catalog = student database;User Id = sa;Password = 123456" ;
            using (SqlConnection con = new SqlConnection(constr))
            {
                string upd = "insert into Student values('221600432','邱志勇' )";
                SqlCommand cmd = new SqlCommand(upd,con);
                con.Open();
                int r = cmd.ExecuteNonQuery();
                Console.WriteLine("成功插入{0}条记录",r);
            }

            Console.WriteLine("断开连接");
            Console.ReadLine();
            #endregion

            #region 类似java preparedstatement 的
            using (SqlConnection connection = new SqlConnection(constr))
            {

                connection.Open();
                SqlCommand sqlcom = new SqlCommand();
                sqlcom.Connection = connection;
                sqlcom.CommandText = "select * from Student where number=@number ";
                sqlcom.Parameters.AddWithValue("@number", "221600432");

                sqlcom.ExecuteNonQuery();
            }
            #endregion


        }
    }
}
#endregion

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值