如何利用C#通過(guò)sql語(yǔ)句操作Sqlserver數(shù)據(jù)庫(kù)教程
必要準(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ù)端,文中實(shí)例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07C#中免費(fèi)密碼庫(kù)BouncyCastle的使用詳解
這篇文章主要來(lái)和大家分享一個(gè)C#版開(kāi)源、免費(fèi)的Bouncy?Castle密碼庫(kù):BouncyCastle,文中介紹了BouncyCastle的具體使用,需要的可以參考下2024-03-03C#實(shí)現(xiàn)EPL?II格式打印與打印測(cè)試
這篇文章介紹了C#實(shí)現(xiàn)EPL?II格式打印與打印測(cè)試的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06