欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何利用C#通過(guò)sql語(yǔ)句操作Sqlserver數(shù)據(jù)庫(kù)教程

 更新時(shí)間:2022年10月27日 09:31:26   作者:予我心安A3  
ado.net提供了豐富的數(shù)據(jù)庫(kù)操作,下面這篇文章主要給大家介紹了關(guān)于如何利用C#通過(guò)sql語(yǔ)句操作Sqlserver數(shù)據(jù)庫(kù)教程的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

必要準(zhǔn)備

你得有一個(gè)sqlserver數(shù)據(jù)庫(kù),并且要和vs項(xiàng)目連接。

關(guān)于VS連接sqlserver數(shù)據(jù)庫(kù)的教程前幾天發(fā)過(guò)了,鏈接如下

VS2022連接sqlserver數(shù)據(jù)庫(kù)教程

 調(diào)用用于訪問(wèn)和控制數(shù)據(jù)庫(kù)的程序集。還得確保你真的安裝了這個(gè)程序集

using System.Data.SqlClient;

 安裝好如下才對(duì)

填寫(xiě)連接參數(shù)字符串

無(wú)賬號(hào)密碼的數(shù)據(jù)庫(kù)服務(wù)器(windows用戶(hù)認(rèn)證)這樣寫(xiě)即可

string connStr = "Data Source=LAPTOP-82MUPKTO;Initial Catalog=CSDN予我心安A3的數(shù)據(jù)庫(kù);Integrated Security=True";
 
//LAPTOP-82MUPKTO      連接的數(shù)據(jù)庫(kù)服務(wù)器名
//CSDN予我心安A3的數(shù)據(jù)庫(kù)   連接的數(shù)據(jù)庫(kù)名

有賬號(hào)密碼登錄的數(shù)據(jù)庫(kù)服務(wù)器(sqlserver身份認(rèn)證)這樣寫(xiě)

 string connStr = "Data Source=服務(wù)器名;Initial Catalog=數(shù)據(jù)庫(kù)名;User ID = 賬號(hào);Password=密碼";

將連接參數(shù)字符串傳入數(shù)據(jù)庫(kù)鏈接類(lèi),生成鏈接對(duì)象conn

SqlConnection conn = new SqlConnection(connStr);
//SqlConnection 變量名 = new SqlConnection(參數(shù)字符串或存儲(chǔ)了參數(shù)字符串的變量);

進(jìn)行鏈接的測(cè)試,運(yùn)行不報(bào)錯(cuò)即鏈接成功

conn.Open();//打開(kāi)數(shù)據(jù)庫(kù)鏈接,越晚開(kāi)越好
conn.Close();//關(guān)閉數(shù)據(jù)庫(kù)鏈接,用完就關(guān),別掛著

必要準(zhǔn)備已經(jīng)OK了

下面來(lái)講sql語(yǔ)句的編寫(xiě)和執(zhí)行。

SQL語(yǔ)句編寫(xiě)加執(zhí)行

編寫(xiě)

我們定義一個(gè)string類(lèi)型的sql變量來(lái)存儲(chǔ)我們的sql語(yǔ)句,sql語(yǔ)句只需用原本的語(yǔ)法即可,無(wú)需做變化。

sqlserver中創(chuàng)建數(shù)據(jù)表一般是這么寫(xiě)的

這里把他轉(zhuǎn)成一行的,不用管縮進(jìn) 。

string sql = "create table csdn予我心安的數(shù)據(jù)表1(name varchar(8) not null)";

有人會(huì)問(wèn),我的sql語(yǔ)句內(nèi)容要持續(xù)變化,但格式基本不變咋辦??偛荒芰韺?xiě)一條吧。其實(shí)沒(méi)那么折騰,用C#的String.Format()生成sql語(yǔ)句字符串就好了.

比如說(shuō)我要?jiǎng)?chuàng)建的數(shù)據(jù)表名要替換,我們?cè)诒砻@加個(gè)占位符就OK

string tablename="csdn予我心安的數(shù)據(jù)表1";//我是表名
string sql = String.Format("create table {0}(name varchar(8) not null)", tablename);
//tablename的內(nèi)容會(huì)替換掉字符串中的{0},所以sql的內(nèi)容會(huì)隨著tablename變換而改變

執(zhí)行

創(chuàng)建執(zhí)行器

sql語(yǔ)句我們已經(jīng)寫(xiě)好了,接下了就要執(zhí)行了

我們調(diào)用SqlCommand類(lèi)生成一個(gè)sql語(yǔ)句執(zhí)行器cmd,傳入sql語(yǔ)句和鏈接變量

SqlCommand cmd = new SqlCommand(sql, conn);
//格式:    SqlCommand 自定義執(zhí)行器變量名= new SqlCommand(sql字符串變量, 鏈接變量);

執(zhí)行器我們創(chuàng)建好了,接下來(lái)要選擇執(zhí)行方法,不同的執(zhí)行方法有不同的返回值。

特別提醒:使用前記得打開(kāi)鏈接

conn.Open();

ExecuteNonQuery()方式執(zhí)行

cmd.ExecuteNonQuery();

 ExecuteScalar()方式執(zhí)行

cmd.ExecuteScalar();

二者區(qū)別 

 ExecuteReader()方式執(zhí)行

cmd.ExecuteReader();

這個(gè)執(zhí)行方式的作用我會(huì)在下面的實(shí)例中詳細(xì)講解

特別提醒:執(zhí)行完請(qǐng)關(guān)閉連接

conn.Close();

實(shí)例:

1-創(chuàng)建一張數(shù)據(jù)表

為小明創(chuàng)建一張個(gè)人成績(jī)表

要用到sql語(yǔ)句中創(chuàng)建數(shù)據(jù)表的指令

create table 表名
(
    列名 數(shù)據(jù)類(lèi)型 是否允許為空(null||not null),
    列名2 數(shù)據(jù)類(lèi)型 是否允許為空(null||not null),
    列名3 數(shù)據(jù)類(lèi)型 是否允許為空(null||not null),
        ……
    列名n 數(shù)據(jù)類(lèi)型  是否允許為空(null||not null)
)

C#代碼 

    using System.Data.SqlClient;//頭別忘了,如果加了頭還顯示未調(diào)用,請(qǐng)檢查Nuget包
 
    public static void addtable(string tablename)
    {
        //測(cè)試連接數(shù)據(jù)庫(kù)
        string connStr = "Data Source=LAPTOP-82MUPKTO;Initial Catalog=CSDN予我心安A3的數(shù)據(jù)庫(kù);Integrated Security=True";
        SqlConnection conn = new SqlConnection(connStr);
        //打開(kāi)數(shù)據(jù)庫(kù)
        conn.Open();
 
        //編寫(xiě)sql語(yǔ)句,語(yǔ)法即sql語(yǔ)法
        string sql = String.Format("create table {0}(課程名 varchar(11) not null,成績(jī)  tinyint     not null)", tablename);
        SqlCommand cmd = new SqlCommand(sql, conn);
        //貼心,異常處理都安排上了
        try
        {
            cmd.ExecuteNonQuery();
            Console.WriteLine("數(shù)據(jù)表創(chuàng)建成功");
        }
        catch (SqlException ae)
        {
            Console.WriteLine("數(shù)據(jù)表創(chuàng)建失敗");
            Console.WriteLine(ae.Message);
        }
        finally
        {
            conn.Close();//對(duì)數(shù)據(jù)庫(kù)操作完成后,需要關(guān)閉數(shù)據(jù)庫(kù),釋放內(nèi)存
        }
 
    }
    addtable("考試成績(jī)表")

蕪湖起飛 

2-向表中插入數(shù)據(jù)

小明的計(jì)算機(jī)科學(xué)考試考了100分,幫他錄進(jìn)去

要用到sql中的插入數(shù)據(jù)指令

insert into 表名
values
('數(shù)據(jù)1','數(shù)據(jù)2','數(shù)據(jù)3')//第一行數(shù)據(jù),表結(jié)構(gòu)有幾列就幾個(gè)唄,允許為空的地方可以就打''
('數(shù)據(jù)1','數(shù)據(jù)2','數(shù)據(jù)3')//第二行數(shù)據(jù),表結(jié)構(gòu)有幾列就幾個(gè)唄,允許為空的地方可以就打''
    public static void adddata(string classname,int grade)
    {
        //測(cè)試連接數(shù)據(jù)庫(kù)
        string connStr = "Data Source=LAPTOP-82MUPKTO;Initial Catalog=CSDN予我心安A3的數(shù)據(jù)庫(kù);Integrated Security=True";
        SqlConnection conn = new SqlConnection(connStr);
        //打開(kāi)數(shù)據(jù)庫(kù)
        conn.Open();
 
        //編寫(xiě)sql語(yǔ)句,語(yǔ)法即sql語(yǔ)法
        string sql = String.Format("insert into 考試成績(jī)表 values('{0}','{1}')",classname,grade);
        SqlCommand cmd = new SqlCommand(sql, conn);
        try
        {
            cmd.ExecuteNonQuery();
            Console.WriteLine("成績(jī)錄入成功");
        }
        catch (SqlException ae)
        {
            Console.WriteLine("成績(jī)錄入失敗");
            Console.WriteLine(ae.Message);
        }
        finally
        {
            conn.Close();//對(duì)數(shù)據(jù)庫(kù)操作完成后,需要關(guān)閉數(shù)據(jù)庫(kù),釋放內(nèi)存
        }
    }
data_Control.adddata("計(jì)算機(jī)科學(xué)",100);

3-修改表中數(shù)據(jù) 

我去,小明考試作弊被發(fā)現(xiàn),成績(jī)0分,幫他改過(guò)來(lái)

update 表名
set 列名1='值',列名2='值' where 篩選條件
    public static void changedata(string classname,int new_grade)
    {
        //測(cè)試連接數(shù)據(jù)庫(kù)
        string connStr = "Data Source=LAPTOP-82MUPKTO;Initial Catalog=CSDN予我心安A3的數(shù)據(jù)庫(kù);Integrated Security=True";
        SqlConnection conn = new SqlConnection(connStr);
        //打開(kāi)數(shù)據(jù)庫(kù)
        conn.Open();
 
        //編寫(xiě)sql語(yǔ)句,語(yǔ)法即sql語(yǔ)法
        string sql = String.Format("update 考試成績(jī)表 set 成績(jī)='{0}' where 課程名='{1}'", new_grade,classname);
        SqlCommand cmd = new SqlCommand(sql, conn);
        try
        {
            cmd.ExecuteNonQuery();
            Console.WriteLine("成績(jī)修改成功");
        }
        catch (SqlException ae)
        {
            Console.WriteLine("成績(jī)修改失敗");
            Console.WriteLine(ae.Message);
        }
        finally
        {
            conn.Close();//對(duì)數(shù)據(jù)庫(kù)操作完成后,需要關(guān)閉數(shù)據(jù)庫(kù),釋放內(nèi)存
        }
    }
 
changedata("計(jì)算機(jī)科學(xué)",0);

4-刪除表中數(shù)據(jù)

小明害怕被老爸竹筍炒肉絲,給我1包辣條賄賂我刪掉這條記錄,我肯定不會(huì)為了一包辣條就幫他

,但他拿了2包就是另一回事了。

delete from 表名 where 篩選條件
    public static void delete_data(string classname)
    {
        //測(cè)試連接數(shù)據(jù)庫(kù)
        string connStr = "Data Source=LAPTOP-82MUPKTO;Initial Catalog=CSDN予我心安A3的數(shù)據(jù)庫(kù);Integrated Security=True";
        SqlConnection conn = new SqlConnection(connStr);
        //打開(kāi)數(shù)據(jù)庫(kù)
        conn.Open();
 
        //編寫(xiě)sql語(yǔ)句,語(yǔ)法即sql語(yǔ)法
        string sql = String.Format("delete from 考試成績(jī)表 where 課程名='{0}'", classname);
        SqlCommand cmd = new SqlCommand(sql, conn);
        try
        {
            cmd.ExecuteNonQuery();
            Console.WriteLine("成績(jī)刪除成功");
        }
        catch (SqlException ae)
        {
            Console.WriteLine("成績(jī)刪除失敗");
            Console.WriteLine(ae.Message);
        }
        finally
        {
            conn.Close();//對(duì)數(shù)據(jù)庫(kù)操作完成后,需要關(guān)閉數(shù)據(jù)庫(kù),釋放內(nèi)存
        }
    }
 
delete_data("計(jì)算機(jī)科學(xué)");

小明開(kāi)心的回家了,他一走我又把成績(jī)寫(xiě)回去了……

5-讀取表中數(shù)據(jù)

學(xué)校要把小明的成績(jī)單打印出來(lái)。

 ExecuteReader()的用法來(lái)了啊,謝謝你看到這里。

用法就在下面的代碼中啦

select * from 考試成績(jī)表
    public static void get_data()
    {
        //測(cè)試連接數(shù)據(jù)庫(kù)
        string connStr = "Data Source=LAPTOP-82MUPKTO;Initial Catalog=CSDN予我心安A3的數(shù)據(jù)庫(kù);Integrated Security=True";
        SqlConnection conn = new SqlConnection(connStr);
        //打開(kāi)數(shù)據(jù)庫(kù)
        conn.Open();
 
        //編寫(xiě)sql語(yǔ)句,語(yǔ)法即sql語(yǔ)法
        string sql = String.Format("select * from 考試成績(jī)表");
        SqlCommand cmd = new SqlCommand(sql, conn);
 
        SqlDataReader rdr = cmd.ExecuteReader();//定義數(shù)據(jù)讀取器rdr獲取傳回的數(shù)據(jù)
        while (rdr.Read())//每次執(zhí)行一次Read(),從數(shù)據(jù)里讀取一行數(shù)據(jù)
        {
            string classname=rdr["課程名"].ToString();//根據(jù)列名,獲得該行里的課程名信息,由于rdr["課程名"]返回的是object類(lèi)型,所以要進(jìn)行類(lèi)型轉(zhuǎn)化,下面成績(jī)一樣的原理
            int grade = Convert.ToInt32(rdr["成績(jī)"]);//根據(jù)列名,獲得該行里的成績(jī)信息
            Console.WriteLine("課程名:{0},成績(jī):{1}",classname,grade);
        }
        conn.Close();//讀取時(shí)要一直保證數(shù)據(jù)庫(kù)是打開(kāi)的
 
    }
 

 小明傷心的拿著成績(jī)單走了..........

總結(jié)

到此這篇關(guān)于如何利用C#通過(guò)sql語(yǔ)句操作Sqlserver數(shù)據(jù)庫(kù)教程的文章就介紹到這了,更多相關(guān)C# sql語(yǔ)句操作Sqlserver數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C# 實(shí)現(xiàn)FTP客戶(hù)端的小例子

    C# 實(shí)現(xiàn)FTP客戶(hù)端的小例子

    這篇文章主要介紹了C# 如何實(shí)現(xiàn)FTP客戶(hù)端,文中實(shí)例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • C#6.0新語(yǔ)法示例詳解

    C#6.0新語(yǔ)法示例詳解

    這篇文章主要給大家介紹了關(guān)于C#6.0新語(yǔ)法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • C#編程高并發(fā)的幾種處理方法詳解

    C#編程高并發(fā)的幾種處理方法詳解

    這篇文章主要為大家詳細(xì)介紹了C#編程高并發(fā)的幾種處理方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C#中使用資源的方法分析

    C#中使用資源的方法分析

    這篇文章主要介紹了C#中使用資源的方法,較為詳細(xì)的對(duì)比分析了C#中使用資源的幾種常用方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-12-12
  • C#委托delegate實(shí)例解析

    C#委托delegate實(shí)例解析

    這篇文章主要介紹了C#委托delegate實(shí)例解析,對(duì)C#的委托做了較為深入的剖析,很適合初學(xué)者學(xué)習(xí),需要的朋友可以參考下
    2014-08-08
  • Unity實(shí)現(xiàn)切割圖集工具

    Unity實(shí)現(xiàn)切割圖集工具

    這篇文章主要為大家詳細(xì)介紹了Unity實(shí)現(xiàn)切割圖集工具,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • C#中免費(fèi)密碼庫(kù)BouncyCastle的使用詳解

    C#中免費(fèi)密碼庫(kù)BouncyCastle的使用詳解

    這篇文章主要來(lái)和大家分享一個(gè)C#版開(kāi)源、免費(fèi)的Bouncy?Castle密碼庫(kù):BouncyCastle,文中介紹了BouncyCastle的具體使用,需要的可以參考下
    2024-03-03
  • C#檢測(cè)DataSet是否為空的方法

    C#檢測(cè)DataSet是否為空的方法

    這篇文章主要介紹了C#檢測(cè)DataSet是否為空的方法,涉及C#操作DataSet的技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下
    2015-04-04
  • C#實(shí)現(xiàn)EPL?II格式打印與打印測(cè)試

    C#實(shí)現(xiàn)EPL?II格式打印與打印測(cè)試

    這篇文章介紹了C#實(shí)現(xiàn)EPL?II格式打印與打印測(cè)試的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • C#中this的用法集錦

    C#中this的用法集錦

    本文給大家匯總介紹了C#中的幾種this用法,相信大家應(yīng)該有用過(guò),但你用過(guò)幾種?以下是個(gè)人總結(jié)的this幾種用法,歡迎大家拍磚,廢話少說(shuō),直接列出用法及相關(guān)代碼。
    2015-06-06

最新評(píng)論