![C#程序設(shè)計(jì)(第2版)7-1課件_第1頁](http://file4.renrendoc.com/view/a0ef90ab84d4bf68504b026889511ac1/a0ef90ab84d4bf68504b026889511ac11.gif)
![C#程序設(shè)計(jì)(第2版)7-1課件_第2頁](http://file4.renrendoc.com/view/a0ef90ab84d4bf68504b026889511ac1/a0ef90ab84d4bf68504b026889511ac12.gif)
![C#程序設(shè)計(jì)(第2版)7-1課件_第3頁](http://file4.renrendoc.com/view/a0ef90ab84d4bf68504b026889511ac1/a0ef90ab84d4bf68504b026889511ac13.gif)
![C#程序設(shè)計(jì)(第2版)7-1課件_第4頁](http://file4.renrendoc.com/view/a0ef90ab84d4bf68504b026889511ac1/a0ef90ab84d4bf68504b026889511ac14.gif)
![C#程序設(shè)計(jì)(第2版)7-1課件_第5頁](http://file4.renrendoc.com/view/a0ef90ab84d4bf68504b026889511ac1/a0ef90ab84d4bf68504b026889511ac15.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
單元7綜合應(yīng)用《C#程序設(shè)計(jì)》課程概述單元7綜合應(yīng)用《C#程序設(shè)計(jì)》課程概述1學(xué)習(xí)內(nèi)容什么是三層架構(gòu)和實(shí)體類0102如何搭建三層架構(gòu)學(xué)習(xí)內(nèi)容什么是三層架構(gòu)和實(shí)體類0102如何搭建三層架構(gòu)2目錄頁P(yáng)AGEOFCONTENT01新建項(xiàng)目02認(rèn)識(shí)項(xiàng)目文件03開始編寫C#代碼04編譯、調(diào)試項(xiàng)目目錄頁P(yáng)AGEOFCONTENT01新建項(xiàng)目02認(rèn)識(shí)項(xiàng)3知識(shí)點(diǎn)名稱根據(jù)自己的需要添加適當(dāng)?shù)奈淖郑瑩?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)自己的需要添加適當(dāng)?shù)奈淖郑瑩?jù)研究,在幻燈片中,一頁的文字最好不要超過200字添加內(nèi)容添加內(nèi)容添加內(nèi)容添加內(nèi)容知識(shí)點(diǎn)名稱根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈4什么是三層架構(gòu)和實(shí)體類01什么是三層架構(gòu)和實(shí)體類0151什么是三層架構(gòu)和實(shí)體類一種代碼的組織形式,其中包括:表示層(UI)、業(yè)務(wù)邏輯層(BLL)和數(shù)據(jù)訪問層(DAL)1)表示層:為用戶提供交互操作界面,用于顯示和接收用戶提交的數(shù)據(jù),為用戶提供交互式的界面。表示層一般為Windows窗體應(yīng)用程序或Web應(yīng)用程序。2)業(yè)務(wù)邏輯層:負(fù)責(zé)關(guān)鍵業(yè)務(wù)的處理和數(shù)據(jù)的傳遞,不會(huì)直接對(duì)數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行操作,該層一般為類庫。3)數(shù)據(jù)訪問層:負(fù)責(zé)數(shù)據(jù)庫數(shù)據(jù)的訪問,根據(jù)傳入的值來操作數(shù)據(jù)庫,實(shí)現(xiàn)對(duì)數(shù)據(jù)的讀取、保存和更新等操作。數(shù)據(jù)訪問層通常為類庫。1什么是三層架構(gòu)和實(shí)體類一種代碼的組織形式,其中包括:表示層61什么是三層架構(gòu)和實(shí)體類為便于在各層間傳遞數(shù)據(jù),通常再添加一個(gè)類庫,即實(shí)體類庫。其中封裝的每個(gè)類都對(duì)應(yīng)一個(gè)實(shí)體,即數(shù)據(jù)庫中的一張表。1什么是三層架構(gòu)和實(shí)體類為便于在各層間傳遞數(shù)據(jù),通常再添加一7如何搭建三層架構(gòu)02如何搭建三層架構(gòu)028如何搭建三層架構(gòu)2將【例6.8】中顯示表T_Stu學(xué)生信息的代碼用三層架構(gòu)來重新進(jìn)行組織1)創(chuàng)建表示層2)創(chuàng)建業(yè)務(wù)邏輯層3)創(chuàng)建數(shù)據(jù)訪問層4)創(chuàng)建實(shí)體類5)添加各層之間依賴關(guān)系如何搭建三層架構(gòu)2將【例6.8】中顯示表T_Stu學(xué)生信息的9如何搭建三層架構(gòu)2添加代碼1)在實(shí)體類庫定義類Student2)在數(shù)據(jù)訪問層定義數(shù)據(jù)庫操作類DBHelper3)在數(shù)據(jù)訪問層定義數(shù)據(jù)訪問類StuService4)在業(yè)務(wù)邏輯層定義類StuManager5)編寫表示層如何搭建三層架構(gòu)2添加代碼10單元7綜合應(yīng)用《C#程序設(shè)計(jì)》課程基于三層架構(gòu)操作數(shù)據(jù)單元7綜合應(yīng)用《C#程序設(shè)計(jì)》課程基于三層架構(gòu)操作數(shù)據(jù)11學(xué)習(xí)內(nèi)容什么是三層架構(gòu)和實(shí)體類0102如何搭建三層架構(gòu)學(xué)習(xí)內(nèi)容什么是三層架構(gòu)和實(shí)體類0102如何搭建三層架構(gòu)12目錄頁P(yáng)AGEOFCONTENT01實(shí)現(xiàn)學(xué)生信息的添加02實(shí)現(xiàn)學(xué)生信息的修改03實(shí)現(xiàn)學(xué)生信息的刪除目錄頁P(yáng)AGEOFCONTENT01實(shí)現(xiàn)學(xué)生信息的添加13知識(shí)點(diǎn)名稱根據(jù)自己的需要添加適當(dāng)?shù)奈淖郑瑩?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字添加內(nèi)容添加內(nèi)容添加內(nèi)容添加內(nèi)容知識(shí)點(diǎn)名稱根據(jù)自己的需要添加適當(dāng)?shù)奈淖郑瑩?jù)研究,在幻燈14實(shí)現(xiàn)學(xué)生信息的添加01實(shí)現(xiàn)學(xué)生信息的添加0115實(shí)現(xiàn)學(xué)生信息的添加1(1)在數(shù)據(jù)訪問層類StuService中添加AddStudent方法public
boolAddStudent(StudentnewStu)
{
stringsqlStr="insertintoT_Stuvalues(@ID,@name,@age)";
SqlParameter[]param=new
SqlParameter[]{
new
SqlParameter("@ID",newStu.ID),
new
SqlParameter("@name",newStu.Name),
new
SqlParameter("@age",newStu.Age)};
return
DBHelper.ExcuteCommand(sqlStr,param);}實(shí)現(xiàn)學(xué)生信息的添加1(1)在數(shù)據(jù)訪問層類StuService16實(shí)現(xiàn)學(xué)生信息的添加(2)在業(yè)務(wù)邏輯層類StuManager中添加AddStudent方法
public
boolAddStudent(StudentnewStu){
returnstu.AddStudent(newStu);}1實(shí)現(xiàn)學(xué)生信息的添加(2)在業(yè)務(wù)邏輯層類StuManager中17實(shí)現(xiàn)學(xué)生信息的添加(3)在表示層獲取輸入的學(xué)生信息
private
voidbtnAdd_Click(objectsender,EventArgse){
StudentnewStu=new
Student();newStu.ID=int.Parse(txtID.Text);newStu.Name=txtName.Text;newStu.Age=int.Parse(txtAge.Text);
if(stu.AddStudent(newStu)){
MessageBox.Show("添加成功");dataGridView1.DataSource=stu.GetStudentList();}
else
MessageBox.Show("添加失敗");}1實(shí)現(xiàn)學(xué)生信息的添加(3)在表示層獲取輸入的學(xué)生信息118實(shí)現(xiàn)學(xué)生信息的修改02實(shí)現(xiàn)學(xué)生信息的修改0219實(shí)現(xiàn)學(xué)生信息的修改2(1)在數(shù)據(jù)訪問層類StuService中添加UpdateStudent方法
public
boolUpdateStudent(Studentstu){
stringsqlstr="updateT_Stusetname=@name,age=@agewhereID=@id";
SqlParameter[]param=new
SqlParameter[]{
new
SqlParameter("@name",stu.Name),
new
SqlParameter("@age",stu.Age),
new
SqlParameter("@ID",stu.ID)};
return
DBHelper.ExcuteCommand(sqlstr,param);}實(shí)現(xiàn)學(xué)生信息的修改2(1)在數(shù)據(jù)訪問層類StuService20實(shí)現(xiàn)學(xué)生信息的修改2(2)在業(yè)務(wù)邏輯層類StuManager中添加UpdateStudent方法
public
boolUpdateStudent(Students){
returnstu.UpdateStudent(s);}實(shí)現(xiàn)學(xué)生信息的修改2(2)在業(yè)務(wù)邏輯層類StuManager21實(shí)現(xiàn)學(xué)生信息的修改2(3)在表示層獲取要修改的學(xué)生信息private
voiddataGridView1_CellClick(objectsender,DataGridViewCellEventArgse){
if(dataGridView1.SelectedRows.Count<=0) {
MessageBox.Show("請(qǐng)選中一行進(jìn)行操作");
return;}txtID.Text=dataGridView1.SelectedRows[0].Cells[0].Value.ToString();txtName.Text=dataGridView1.SelectedRows[0].Cells[1].Value.ToString();txtAge.Text=dataGridView1.SelectedRows[0].Cells[2].Value.ToString();}
private
voidbtnUpdate_Click(objectsender,EventArgse){
if(dataGridView1.SelectedRows.Count<=0) {
MessageBox.Show("請(qǐng)選中一行進(jìn)行操作");
return;}
StudentnewStu=new
Student();newStu.ID=int.Parse(dataGridView1.SelectedRows[0].Cells[0].Value.ToString());newStu.Name=txtName.Text;newStu.Age=int.Parse(txtAge.Text);
//保存修改
if(stu.UpdateStudent(newStu)){
MessageBox.Show("修改成功");dataGridView1.DataSource=stu.GetStudentList();}
else
MessageBox.Show("修改失敗");}實(shí)現(xiàn)學(xué)生信息的修改2(3)在表示層獲取要修改的學(xué)生信息22實(shí)現(xiàn)學(xué)生信息的刪除03實(shí)現(xiàn)學(xué)生信息的刪除0323實(shí)現(xiàn)學(xué)生信息的刪除3(1)在數(shù)據(jù)訪問層類DBHelper中添加ExcuteCommand方法的重載public
static
boolExcuteCommand(List<String>sqlStr,List<SqlParameter[]>param){
inti=0;SqlCommandcmd=new
SqlCommand();
using(TransactionScopets=new
TransactionScope()){cmd.Connection=conn;conn.Open();
try{
foreach(stringiteminsqlStr){cmd.CommandType=CommandType.Text; cmd.CommandText=item;
cmd.Parameters.AddRange(param[i]); //添加參數(shù)cmd.ExecuteNonQuery(); //執(zhí)行SQL語句并返回受影響的行數(shù)
i++;
}ts.Complete();
return
true;}
catch{return
false;}
finally{conn.Close();sqlStr.Clear();}}}實(shí)現(xiàn)學(xué)生信息的刪除3(1)在數(shù)據(jù)訪問層類DBHelper中添24(2)在數(shù)據(jù)訪問層類StuService中添加DelStudent方法public
boolDelStudent(intid){
List<String>strSqls=new
List<string>(); //創(chuàng)建集合對(duì)象
List<SqlParameter[]>param=new
List<SqlParameter[]>();
stringstrDelete1="deleteFromT_StuwhereID=@id"; //定義刪除表T_Stu的SQL語句strSqls.Add(strDelete1); //將SQL語句添加到集合中
SqlParameter[]param1=new
SqlParameter[]{
new
SqlParameter("@ID",id)};param.Add(param1);
stringstrDelete2="deleteFromT_SCwhereSno=@sno"; //定義刪除表T_SC的SQL語句strSqls.Add(strDelete2); //將SQL語句添加到集合中
SqlParameter[]param2=new
SqlParameter[]{
new
SqlParameter("@sno",id)};param.Add(param2);
return
DBHelper.ExcuteCommand(strSqls,param);}實(shí)現(xiàn)學(xué)生信息的刪除3(2)在數(shù)據(jù)訪問層類StuService中添加DelStud25(3)在業(yè)務(wù)邏輯層類StuManager中添加DelStudent方法public
boolDelStudent(intid){
returnstu.DelStudent(id);}實(shí)現(xiàn)學(xué)生信息的刪除3(3)在業(yè)務(wù)邏輯層類StuManager中添加DelStud26(4)在表示層獲取待刪除學(xué)生的學(xué)號(hào)private
voidbtnDel_Click(objectsender,EventArgse){
intid;
if(dataGridView1.SelectedRows.Count<=0) {
MessageBox.Show("請(qǐng)選中一行進(jìn)行操作");
return;}id=int.Parse(dataGridView1.SelectedRows[0].Cells[0].Value.ToString());
if(stu.DelStudent(id)){
MessageBox.Show("刪除成功");dataGridView1.DataSource=stu.GetStudentList();txtID.Text="";txtName.Text="";txtAge.Text="";}
else
MessageBox.Show("刪除失敗");}實(shí)現(xiàn)學(xué)生信息的刪除3(4)在表示層獲取待刪除學(xué)生的學(xué)號(hào)實(shí)現(xiàn)學(xué)生信息的刪除327謝謝學(xué)習(xí)謝謝學(xué)習(xí)28單元7綜合應(yīng)用《C#程序設(shè)計(jì)》課程概述單元7綜合應(yīng)用《C#程序設(shè)計(jì)》課程概述29學(xué)習(xí)內(nèi)容什么是三層架構(gòu)和實(shí)體類0102如何搭建三層架構(gòu)學(xué)習(xí)內(nèi)容什么是三層架構(gòu)和實(shí)體類0102如何搭建三層架構(gòu)30目錄頁P(yáng)AGEOFCONTENT01新建項(xiàng)目02認(rèn)識(shí)項(xiàng)目文件03開始編寫C#代碼04編譯、調(diào)試項(xiàng)目目錄頁P(yáng)AGEOFCONTENT01新建項(xiàng)目02認(rèn)識(shí)項(xiàng)31知識(shí)點(diǎn)名稱根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字添加內(nèi)容添加內(nèi)容添加內(nèi)容添加內(nèi)容知識(shí)點(diǎn)名稱根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈32什么是三層架構(gòu)和實(shí)體類01什么是三層架構(gòu)和實(shí)體類01331什么是三層架構(gòu)和實(shí)體類一種代碼的組織形式,其中包括:表示層(UI)、業(yè)務(wù)邏輯層(BLL)和數(shù)據(jù)訪問層(DAL)1)表示層:為用戶提供交互操作界面,用于顯示和接收用戶提交的數(shù)據(jù),為用戶提供交互式的界面。表示層一般為Windows窗體應(yīng)用程序或Web應(yīng)用程序。2)業(yè)務(wù)邏輯層:負(fù)責(zé)關(guān)鍵業(yè)務(wù)的處理和數(shù)據(jù)的傳遞,不會(huì)直接對(duì)數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行操作,該層一般為類庫。3)數(shù)據(jù)訪問層:負(fù)責(zé)數(shù)據(jù)庫數(shù)據(jù)的訪問,根據(jù)傳入的值來操作數(shù)據(jù)庫,實(shí)現(xiàn)對(duì)數(shù)據(jù)的讀取、保存和更新等操作。數(shù)據(jù)訪問層通常為類庫。1什么是三層架構(gòu)和實(shí)體類一種代碼的組織形式,其中包括:表示層341什么是三層架構(gòu)和實(shí)體類為便于在各層間傳遞數(shù)據(jù),通常再添加一個(gè)類庫,即實(shí)體類庫。其中封裝的每個(gè)類都對(duì)應(yīng)一個(gè)實(shí)體,即數(shù)據(jù)庫中的一張表。1什么是三層架構(gòu)和實(shí)體類為便于在各層間傳遞數(shù)據(jù),通常再添加一35如何搭建三層架構(gòu)02如何搭建三層架構(gòu)0236如何搭建三層架構(gòu)2將【例6.8】中顯示表T_Stu學(xué)生信息的代碼用三層架構(gòu)來重新進(jìn)行組織1)創(chuàng)建表示層2)創(chuàng)建業(yè)務(wù)邏輯層3)創(chuàng)建數(shù)據(jù)訪問層4)創(chuàng)建實(shí)體類5)添加各層之間依賴關(guān)系如何搭建三層架構(gòu)2將【例6.8】中顯示表T_Stu學(xué)生信息的37如何搭建三層架構(gòu)2添加代碼1)在實(shí)體類庫定義類Student2)在數(shù)據(jù)訪問層定義數(shù)據(jù)庫操作類DBHelper3)在數(shù)據(jù)訪問層定義數(shù)據(jù)訪問類StuService4)在業(yè)務(wù)邏輯層定義類StuManager5)編寫表示層如何搭建三層架構(gòu)2添加代碼38單元7綜合應(yīng)用《C#程序設(shè)計(jì)》課程基于三層架構(gòu)操作數(shù)據(jù)單元7綜合應(yīng)用《C#程序設(shè)計(jì)》課程基于三層架構(gòu)操作數(shù)據(jù)39學(xué)習(xí)內(nèi)容什么是三層架構(gòu)和實(shí)體類0102如何搭建三層架構(gòu)學(xué)習(xí)內(nèi)容什么是三層架構(gòu)和實(shí)體類0102如何搭建三層架構(gòu)40目錄頁P(yáng)AGEOFCONTENT01實(shí)現(xiàn)學(xué)生信息的添加02實(shí)現(xiàn)學(xué)生信息的修改03實(shí)現(xiàn)學(xué)生信息的刪除目錄頁P(yáng)AGEOFCONTENT01實(shí)現(xiàn)學(xué)生信息的添加41知識(shí)點(diǎn)名稱根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字根據(jù)自己的需要添加適當(dāng)?shù)奈淖?,?jù)研究,在幻燈片中,一頁的文字最好不要超過200字添加內(nèi)容添加內(nèi)容添加內(nèi)容添加內(nèi)容知識(shí)點(diǎn)名稱根據(jù)自己的需要添加適當(dāng)?shù)奈淖郑瑩?jù)研究,在幻燈42實(shí)現(xiàn)學(xué)生信息的添加01實(shí)現(xiàn)學(xué)生信息的添加0143實(shí)現(xiàn)學(xué)生信息的添加1(1)在數(shù)據(jù)訪問層類StuService中添加AddStudent方法public
boolAddStudent(StudentnewStu)
{
stringsqlStr="insertintoT_Stuvalues(@ID,@name,@age)";
SqlParameter[]param=new
SqlParameter[]{
new
SqlParameter("@ID",newStu.ID),
new
SqlParameter("@name",newStu.Name),
new
SqlParameter("@age",newStu.Age)};
return
DBHelper.ExcuteCommand(sqlStr,param);}實(shí)現(xiàn)學(xué)生信息的添加1(1)在數(shù)據(jù)訪問層類StuService44實(shí)現(xiàn)學(xué)生信息的添加(2)在業(yè)務(wù)邏輯層類StuManager中添加AddStudent方法
public
boolAddStudent(StudentnewStu){
returnstu.AddStudent(newStu);}1實(shí)現(xiàn)學(xué)生信息的添加(2)在業(yè)務(wù)邏輯層類StuManager中45實(shí)現(xiàn)學(xué)生信息的添加(3)在表示層獲取輸入的學(xué)生信息
private
voidbtnAdd_Click(objectsender,EventArgse){
StudentnewStu=new
Student();newStu.ID=int.Parse(txtID.Text);newStu.Name=txtName.Text;newStu.Age=int.Parse(txtAge.Text);
if(stu.AddStudent(newStu)){
MessageBox.Show("添加成功");dataGridView1.DataSource=stu.GetStudentList();}
else
MessageBox.Show("添加失敗");}1實(shí)現(xiàn)學(xué)生信息的添加(3)在表示層獲取輸入的學(xué)生信息146實(shí)現(xiàn)學(xué)生信息的修改02實(shí)現(xiàn)學(xué)生信息的修改0247實(shí)現(xiàn)學(xué)生信息的修改2(1)在數(shù)據(jù)訪問層類StuService中添加UpdateStudent方法
public
boolUpdateStudent(Studentstu){
stringsqlstr="updateT_Stusetname=@name,age=@agewhereID=@id";
SqlParameter[]param=new
SqlParameter[]{
new
SqlParameter("@name",stu.Name),
new
SqlParameter("@age",stu.Age),
new
SqlParameter("@ID",stu.ID)};
return
DBHelper.ExcuteCommand(sqlstr,param);}實(shí)現(xiàn)學(xué)生信息的修改2(1)在數(shù)據(jù)訪問層類StuService48實(shí)現(xiàn)學(xué)生信息的修改2(2)在業(yè)務(wù)邏輯層類StuManager中添加UpdateStudent方法
public
boolUpdateStudent(Students){
returnstu.UpdateStudent(s);}實(shí)現(xiàn)學(xué)生信息的修改2(2)在業(yè)務(wù)邏輯層類StuManager49實(shí)現(xiàn)學(xué)生信息的修改2(3)在表示層獲取要修改的學(xué)生信息private
voiddataGridView1_CellClick(objectsender,DataGridViewCellEventArgse){
if(dataGridView1.SelectedRows.Count<=0) {
MessageBox.Show("請(qǐng)選中一行進(jìn)行操作");
return;}txtID.Text=dataGridView1.SelectedRows[0].Cells[0].Value.ToString();txtName.Text=dataGridView1.SelectedRows[0].Cells[1].Value.ToString();txtAge.Text=dataGridView1.SelectedRows[0].Cells[2].Value.ToString();}
private
voidbtnUpdate_Click(objectsender,EventArgse){
if(dataGridView1.SelectedRows.Count<=0) {
MessageBox.Show("請(qǐng)選中一行進(jìn)行操作");
return;}
StudentnewStu=new
Student();newStu.ID=int.Parse(dataGridView1.SelectedRows[0].Cells[0].Value.ToString());newStu.Name=txtName.Text;newStu.Age=int.Parse(txtAge.Text);
//保存修改
if(stu.UpdateStudent(newStu)){
MessageBox.Show("修改成功");dataGridView1.DataSource=stu.GetStudentList();}
else
MessageBox.Show("修改失敗");}實(shí)現(xiàn)學(xué)生信息的修改2(3)在表示層獲取要修改的學(xué)生信息50實(shí)現(xiàn)學(xué)生信息的刪除03實(shí)現(xiàn)學(xué)生信息的刪除0351實(shí)現(xiàn)學(xué)生信息的刪除3(1)在數(shù)據(jù)訪問層類DBHelper中添加ExcuteCommand方法的重載public
static
boolExcuteCommand(List<String>sqlStr,List<SqlParameter[]>param){
inti=0;SqlCommandcmd=new
SqlCommand();
using(TransactionScopets=new
TransactionScope()){cmd.Connection=conn;conn.Open();
try{
foreach(stringiteminsqlStr){cmd.CommandType=CommandType.Text; cmd.CommandText=item;
cmd.Parameters.AddRange(param[i]); //添加參數(shù)cmd.ExecuteNonQuery(); //執(zhí)行SQL語句并返回受影響的行數(shù)
i++;
}ts.Complete();
return
true;}
catch{return
false;}
finally{conn.Close();sqlStr.Clear();}}}實(shí)現(xiàn)學(xué)生信息的刪除3(1)在數(shù)據(jù)訪問層類DBHelper中添52(2)在數(shù)據(jù)訪問層類StuService中添加DelStudent方法public
boolDelStudent(intid){
List<String>strSqls=new
List<string>(); //創(chuàng)建集合對(duì)象
List<SqlParameter[]>param=new
List<SqlParameter[]>();
stringstrDelete1="deleteFromT_StuwhereID=@id"; //
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 岸坡拋石工程施工方案
- 環(huán)保技術(shù)引領(lǐng)未來環(huán)境科學(xué)與城市發(fā)展
- 中小學(xué)生欺凌專項(xiàng)治理行動(dòng)方案
- 現(xiàn)代通信技術(shù)在教育領(lǐng)域的應(yīng)用
- 2024年四年級(jí)英語上冊(cè) Module 5 Unit 2 Can Sam play football說課稿 外研版(三起)001
- 2024八年級(jí)英語下冊(cè) Unit 2 Plant a PlantLesson 7 Planting Trees說課稿(新版)冀教版
- 2024新教材高中政治 第二單元 經(jīng)濟(jì)發(fā)展與社會(huì)進(jìn)步 第四課 我國的個(gè)人收入分配與社會(huì)保障 4.1《我國的個(gè)人收入分配》說課稿 部編版必修2
- Module4 Unit1 Mum bought a new T-shirt for me(說課稿)-2024-2025學(xué)年外研版(三起)英語五年級(jí)上冊(cè)
- 《6 蛋殼與薄殼結(jié)構(gòu)》(說課稿)-2023-2024學(xué)年五年級(jí)下冊(cè)科學(xué)蘇教版
- 2025北京市勞務(wù)分包合同范本問題范本
- 《住院患者身體約束的護(hù)理》團(tuán)體標(biāo)準(zhǔn)解讀課件
- 中國心力衰竭診斷與治療指南解讀
- API520-安全閥計(jì)算PART1(中文版)
- 醫(yī)院信息科考核內(nèi)容標(biāo)準(zhǔn)細(xì)則
- 商務(wù)提成辦法
- 《統(tǒng)計(jì)學(xué)》完整袁衛(wèi)-賈俊平課件
- FZ/T 25001-1992工業(yè)用毛氈
- 電商部售后客服績效考核表
- 小提琴協(xié)奏曲《梁?!纷V
- 人教版高中化學(xué)必修一第一章《物質(zhì)及其變化》教學(xué)課件
- 復(fù)工復(fù)產(chǎn)工作方案范本【復(fù)產(chǎn)復(fù)工安全工作方案】
評(píng)論
0/150
提交評(píng)論