SQL Server的学习记录(未完)

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

namespace sqltest
{
    class Program
    {
        static void Main(string[] args)
        {
            Thread writeThr = new Thread(readData);
            Thread readThr = new Thread(writeData1);
            Thread writeThr2 = new Thread(writeData2);

            writeThr.Start();
            readThr.Start();
        }

        private static void readData()
        {
            Thread.Sleep(20);
            Console.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "  开始读数据.....");
            using (SqlConnection con = new SqlConnection("server=(local);uid=sa;pwd=cqdx2504A;database=abc;pooling=false"))
            {
                con.Open();
                string read = "select * from testCount";
                SqlCommand cmd = new SqlCommand(read, con);
                SqlDataReader reader = cmd.ExecuteReader();
                while (reader.Read())
                {
                    Console.WriteLine(reader[0].ToString());
                }
                con.Close();
            }
            Console.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "  数据读取完毕.....");
            Console.ReadKey();
        }




        private static void writeData1()
        {
            Console.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "1  开始写数据.....");
            using (SqlConnection con = new SqlConnection("server=(local);uid=sa;pwd=------;database=abc;pooling=false"))
            {
                for (int i = 0; i < 1000; i++)
                {
                    con.Open();
                    String insert = "insert into testCount values ('" + 1 + "')";
                    SqlCommand cmd = new SqlCommand(insert, con);
                    cmd.ExecuteReader();
                    con.Close();
                }
            }
            Console.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + " 1 插入完成.....");
        }

        private static void writeData2()
        {
            Console.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + " 2 开始写数据.....");
            using (SqlConnection con = new SqlConnection("server=(local);uid=sa;pwd=--------;database=abc;pooling=false"))
            {
                for (int i = 0; i < 1000; i++)
                {
                    con.Open();
                    String insert = "insert into testCount values ('" + 2 + "')";
                    SqlCommand cmd = new SqlCommand(insert, con);
                    cmd.ExecuteReader();
                    con.Close();
                }
            }
            Console.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + " 2 插入完成.....");
        }
    }
}


这里只是简单的记录一下我自己的想法,多个线程对同一张表进行读写时发生的情况;

注意:正常情况下大量插入一张表数据是不这样插入的,有更方便的方法,下次在论述了,这里我只写了最简单的插入,没有考虑效率什么的...


测试结果说明:

1. 线程read 和write同时操作一张表时,read延迟一秒,write持续插入,而read只读取当前时间内有的数据。

2. 两个write线程同时发生,插入相互之间无影响,数据交替插入。插入数据为两次插入总合。


当发起读操作的时候,数据库正在进行写操作,那么读操作获取到的数据就可能不是最新的,这对于数据库来讲是正确的结论,因为数据库通常认为你要读取的数据是发起SQL查找时的时间点的数据,如果在读取过程中数据发生修改,及时还没有读到修改数据的行,也不应该将修改后的数据返回给客户端,这在数据库中会存在一个时间戳或者版本号的概念来保证对应的数据。



未完待续,继续查看更新时跟插入读取有什么影响。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值