Asp Net ch09 Final
Asp Net ch09 Final
ﻣﻘﺪﻣﻪ :
ﺩﺭ ﺍﻳﻦ ﻓﺼﻞ ﻣﺒﺎﺣﺚ ﺗﻜﻤﻴﻠﻲ ﻛﺎﺭ ﺑﺎ ﺩﻳﺘﺎﺑﻴﺲ ﻫﺎ ﻭ ADO.NETﻣﻮﺭﺩ ﺑﺮﺭﺳﻲ ﻗﺮﺍﺭ ﺧﻮﺍﻫﻨـﺪ ﮔﺮﻓـﺖ ﻣﺎﻧﻨـﺪ
ﺍﺟﺮﺍﻱ ﺭﻭﻳﻪ ﻫﺎﻱ ﺫﺧﻴﺮﻩ ﺷﺪﻩ ،ﺍﻧﺠﺎﻡ ﻋﻤﻠﻴﺎﺕ ﺭﻳﺎﺿﻲ ﺭﻭﻱ ﺳﺘﻮﻥ ﻫﺎ ﻭ ﻏﻴﺮﻩ.
ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺭﻭﻳﻪ ﻫﺎﻱ ﺫﺧﻴﺮﻩ ﺷﺪﻩ ﺩﺭ ﺑﺮﻧﺎﻣـﻪ ﻫـﺎ ،ﺑﺮﻧﺎﻣـﻪ ﺍﻱ ﺳـﺮﻳﻌﺘﺮ ﻭ ﺍﻣـﻦ ﺗـﺮ ﻧﺴـﺒﺖ ﺑـﻪ ﺣـﺎﻟﺘﻲ ﻛـﻪ
ﺩﺳﺘﻮﺭﺍﺕ SQLﺑﻪ ﺻﻮﺭﺕ ﻣﺴﺘﻘﻴﻢ ﺭﻭﻱ ﺩﻳﺘﺎﺑﻴﺲ ﺍﺟﺮﺍ ﻣﻲ ﺷﻮﻧﺪ ﺭﺍ ﺍﻳﺠﺎﺩ ﻣـﻲ ﻛﻨـﺪ .ﻫﻤـﺎﻧﻄﻮﺭ ﻛـﻪ ﺩﺭ ﻃـﻲ
ﻓﺼﻮﻝ ﭘﻴﺸﻴﻦ ﺩﺭ ﻣﻮﺭﺩ ﻧﺤﻮﻩ ﻱ ﺍﻳﺠﺎﺩ ﺁﻧﻬﺎ ﺻﺤﺒﺖ ﺷﺪ ،ﺭﻭﻳﻪ ﻫﺎﻱ ﺫﺧﻴﺮﻩ ﺷـﺪﻩ ﺩﺳـﺘﻮﺭﺍﺕ SQLﻭ ﭘـﻴﺶ
ﻛﺎﻣﭙﺎﻳﻞ ﺷﺪﻩ ﺍﻱ ﺑﻮﺩﻩ ﻭ ﺩﺭ ﺣﺎﻓﻈﻪ ﻱ ﺳﺮﻭﺭ ﺩﻳﺘﺎﺑﻴﺲ ﺷﻤﺎ Cacheﺧﻮﺍﻫﻨﺪ ﺷﺪ .ﻧﺤﻮﻩ ﻱ ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺁﻧﻬﺎ ﺩﺭ
ADO.NETﺑﻪ ﺻﻮﺭﺕ ﻳﻚ ﻣﺜﺎﻝ ﺍﺭﺍﺋﻪ ﺧﻮﺍﻫﺪ ﺷﺪ.
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
1 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﻣﺜﺎﻝ : ١
ﻳﻚ ﺑﺎﻧﻚ ﺍﻃﻼﻋﺎﺗﻲ ﺟﺪﻳﺪ ﺑﻪ ﻧﺎﻡ MyTestDBﺍﻳﺠﺎﺩ ﻛﻨﻴﺪ ﺑﺎ ﺩﻭﺟﺪﻭﻝ ﺑﻪ ﺻﻮﺭﺕ ﺯﻳﺮ .ﻣﻲ ﺧـﻮﺍﻫﻴﻢ ﺍﺯ ﺍﻳـﻦ
ﺩﻭ ﺟﺪﻭﻝ ﮔﺰﺍﺭﺷﻲ ﺗﻬﻴﻪ ﻛﻨﻴﻢ ﻛﻪ ﺑﻪ ﺍﺯﺍﻱ ﻫﺮ IDﺗﻔﺎﺿﻞ ﺗﻌﺪﺍﺩ ﻭﺭﻭﺩﻱ ﻭ ﺗﻌﺪﺍﺩ ﻓﺮﻭﺧﺘﻪ ﺷﺪﻩ ﺑﻪ ﺻﻮﺭﺕ ﻳـﻚ
ﺳﺘﻮﻥ ﻭﺍﺣﺪ ﺩﺭ ﻳﻚ ﺩﻳﺘﺎ ﮔﺮﻳﺪ ﻧﻤﺎﻳﺶ ﺩﺍﺩﻩ ﺷﻮﺩ .ﺑﻬﺘﺮﻳﻦ ،ﻣﻄﻤﺌﻦ ﺗﺮﻳﻦ ﻭ ﺳﺮﻳﻌﺘﺮﻳﻦ ﺭﺍﻩ ﺑﺮﺍﻱ ﺍﻳﻦ ﻧﻮﻉ ﻣﺜﺎﻟﻬﺎ
ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺭﻭﻳﻪ ﻫﺎﻱ ﺫﺧﻴﺮﻩ ﺷﺪﻩ ﻣﻲ ﺑﺎﺷﺪ.
ﺟﺪﻭﻝ : tblEntry
ﺟﺪﻭﻝ : tblSell
ﺩﺭ ﺍﺩﺍﻣﻪ ﻣﻲ ﺧﻮﺍﻫﻴﻢ Foreign keyﺭﺍ ﺍﻳﺠﺎﺩ ﻧﻤﺎﻳﻴﻢ .ﺭﻭﻱ ﺻﻔﺤﻪ ﺩﺭ ﺣﺎﻟـﺖ ﻃﺮﺍﺣـﻲ ﻛﻠﻴـﻚ ﺭﺍﺳـﺖ ﻛﻨﻴـﺪ ﻭ
ﺳﭙﺲ ﮔﺰﻳﻨﻪ ﻱ Relationshipﺭﺍ ﺍﻧﺘﺨﺎﺏ ﻧﻤﺎﻳﻴﺪ )ﺷﻜﻞ : (٣
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
2 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﺩﺭ ﺻﻔﺤﻪ ﻱ ﻇﺎﻫﺮ ﺷﺪﻩ ﺭﻭﻱ Newﻛﻠﻴﻚ ﻛﻨﻴﺪ )ﺷﻜﻞ (٤ﻭ ﺗﻨﻈﻴﻤﺎﺕ ﺻﻔﺤﻪ ﺭﺍ ﻣﺎﻧﻨﺪ ﺷﻜﻞ ﺍﻧﺠﺎﻡ ﺩﻫﻴﺪ.
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
3 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
. (٥ ﺻﻔﺤﻪ ﻱ ﻧﻤﺎﻳﺶ ﺛﺒﺖ ﺗﻐﻴﻴﺮﺍﺕ ﻇﺎﻫﺮ ﺧﻮﺍﻫﺪ ﺷﺪ ) ﺷﻜﻞ، ﻭ ﺩﺭ ﺁﺧﺮ ﭘﺲ ﺍﺯ ﺑﺴﺘﻦ ﺍﻳﻦ ﺻﻔﺤﻪ ﺩﻳﺎﻟﻮﮒ
. ﺭﻭﻳﻪ ﺫﺧﻴﺮﻩ ﺷﺪﻩ ﺯﻳﺮ ﺭﺍ ﺍﻳﺠﺎﺩ ﻛﻨﻴﺪQuery Analyzer ﺩﺭ، ﺑﺮﺍﻱ ﺍﻳﺠﺎﺩ ﺭﻭﻳﻪ ﺫﺧﻴﺮﻩ ﺷﺪﻩ
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
([email protected]) ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ: ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ
4 ASP.NET ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
Enterprise ﺑﺮﺍﻱ ﺍﻳﻨﻜﻪ ﺑﺘﻮﺍﻥ ﺑﺎ ﺩﻳﺘﺎﺑﻴﺲ ﻓﻮﻕ ﻛﺎﺭ ﻛﺮﺩ ﻣﻲ ﺗﻮﺍﻥ ﻳﻚ ﺳﺮﻱ ﺩﺍﺩﻩ ﺭﺍ ﺧﻴﻠﻲ ﺳﺮﻳﻊ ﺩﺭ ﻣﺤﻴﻂ
. ﻭﺍﺭﺩ ﻧﻤﻮﺩmanager
: ﺑﺮﺍﻱ ﺗﺴﺖ ﻛﺮﺩﻥ ﺁﻥ ﻫﻢ ﻣﻲ ﺗﻮﺍﻧﻴﺪ ﺍﺯ ﺩﺳﺘﻮﺭ ﺯﻳﺮ ﺍﺳﺘﻔﺎﺩﻩ ﻛﻨﻴﺪ
Exec rptDiff
SqlDataAdapter sqldataadapterSP =
new SqlDataAdapter("rptDiff",sqlconnectionForum);
sqldataadapterSP.SelectCommand.CommandType =
CommandType.StoredProcedure ;
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
([email protected]) ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ: ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ
5 ASP.NET ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
;DataGrid1.DataSource = datasetSP.Tables["tblEntry"].DefaultView
;)(DataGrid1.DataBind
}
ﻣﺜﺎﻝ : ٢
ﺩﺭ ﺍﻳﻦ ﻣﺜﺎﻝ ﻣﻲ ﺧﻮﺍﻫﻴﻢ ﻧﺤﻮﻩ ﻱ ﭘﺎﺱ ﻛﺮﺩﻥ ﻣﺘﻐﻴﺮﻫﺎ ﻭ ﻭﺭﻭﺩﻱ ﻫﺎﻱ ﻓﺮﻡ ﺭﺍ ﺑـﻪ ﻳـﻚ ﺭﻭﻳـﻪ ﺫﺧﻴـﺮﻩ ﺷـﺪﻩ
ﺑﺮﺭﺳﻲ ﻛﻨﻴﻢ .ﻓﺮﺽ ﻛﻨﻴﻢ ﺩﺭ ﺩﻳﺘﺎﺑﻴﺲ MyTestDBﻛﻪ ﺁﻧﺮﺍ ﺩﺭ ﻣﺜﺎﻝ ﻗﺒﻞ ﺍﻳﺠﺎﺩ ﻛﺮﺩﻳﻢ ﻣﻲ ﺧـﻮﺍﻫﻴﻢ ﺑـﺎ ﺩﺍﺩﻥ
IDﺗﻔﺎﺿﻞ ﺗﻌﺪﺍﺩ ﻭﺭﻭﺩﻱ ﻭ ﺗﻌﺪﺍﺩ ﻓﺮﻭﺧﺘﻪ ﺷﺪﻩ ﺁﻧﺮﺍ ﺑﺪﺳﺖ ﺁﻭﺭﻳﻢ ﻭ ﺭﻭﻱ ﺻﻔﺤﻪ ﻧﻤﺎﻳﺶ ﺩﻫﻴﻢ :
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
6 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
: ﻋﺒﺎﺭﺕ ﺯﻳﺮ ﺭﺍ ﻭﺍﺭﺩ ﻛﺮﺩQuery analyzer ﺑﺮﺍﻱ ﺗﺴﺖ ﻛﺮﺩﻥ ﺁﻥ ﻫﻢ ﻣﻲ ﺗﻮﺍﻥ ﺩﺭ
exec rpt_ID_diff 2
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
([email protected]) ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ: ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ
7 ASP.NET ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
}
ﮔﺎﻫﻲ ﺍﺯ ﺍﻭﻗﺎﺕ ﻻﺯﻡ ﺍﺳﺖ ﺗﺎ ﺑﺮﺍﻱ ﻣﺜﺎﻝ ﺟﻤﻊ ﻛﻞ ﻋﺪﺩﻫﺎﻱ ﻣﻮﺟﻮﺩ ﺩﺭ ﻳﻚ ﺳﺘﻮﻥ ) ﻓﻴﻠﺪ ( ﺭﺍ ﻣﺤﺎﺳﺒﻪ ﻛﻨﻴﻢ ﻭ
ﻳﺎ ﻣﻴﺎﻧﮕﻴﻦ ﻫﺎ ﻭ ﺍﻣﺜﺎﻝ ﺍﻳﻨﮕﻮﻧﻪ ﻋﻤﻠﻴﺎﺕ .ﻳﻜﻲ ﺍﺯ ﺭﺍﻩ ﺣﻞ ﻫﺎ ﺁﻥ ﺑﺪﻳﻦ ﺻﻮﺭﺕ ﺍﺳﺖ ﻛﻪ ﻛﻞ ﺍﻋﺪﺍﺩ ﻓﻴﻠﺪ ﺭﺍ ﺑﺨﻮﺍﻧﻴﻢ
ﻭ ﺳﭙﺲ ﻋﻤﻠﻴﺎﺕ ﺭﻭﻱ ﺁﻥ ﺍﻧﺠﺎﻡ ﺩﻫﻴﻢ ﻭ ﻳﺎ ﺭﺍﻩ ﺩﻳﮕﺮ ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺩﺳـﺘﻮﺭﺍﺕ ﻣﺨﺼـﻮﺹ SQLﺑـﺮﺍﻱ ﺍﻳﻨﮕﻮﻧـﻪ
ﻛﺎﺭﻫﺎ ﻣﻲ ﺑﺎﺷﺪ .ﻣﺜﺎﻝ ﺯﻳﺮ ﻧﺤﻮﻩ ﻱ ﺍﻧﺠﺎﻡ ﺍﻳﻨﮕﻮﻧﻪ ﻋﻤﻠﻴﺎﺕ ﺭﺍ ﺑﻴﺎﻥ ﻣﻲ ﻛﻨﺪ.
ﻣﺜﺎﻝ : ٣
ﻣﻲ ﺧﻮﺍﻫﻴﻢ ﺑﺰﺭﮔﺘﺮﻳﻦ ﻋﺪﺩ ﻣﻮﺟﻮﺩ ﺩﺭ ﻓﻴﻠﺪ myTestDB.dbo.tblSell.IDﻛﻪ ﺩﺭ ﻣﺜﺎﻝ ﺍﻭﻝ ﺍﻳﺠـﺎﺩ ﺷـﺪ ﺭﺍ ﺑﺪﺳـﺖ
ﺁﻭﺭﻳﻢ.
ﺑﺮﺍﻱ ﻧﻮﺷﺘﻦ ﺍﻳﻦ ﺑﺮﻧﺎﻣﻪ ﺭﺍﻩ ﺣﻞ ﻫﺎﻱ ﺯﻳﺎﺩﻱ ﻭﺟﻮﺩ ﺩﺍﺭﺩ ﻛﻪ ﻳﻜﻲ ﺍﺯ ﺁﻧﻬﺎ ﺩﺭ ﺯﻳﺮ ﺑﺮﺭﺳﻲ ﺧﻮﺍﻫﺪ ﺷﺪ .ﺑـﺮﺍﻱ
ﺑﺪﺳﺖ ﺁﻭﺭﺩﻥ ﻳﻚ ﻣﻘﺪﺍﺭ ﺍﺯ ﺩﻳﺘﺎﺑﻴﺲ ﺍﺯ ﻣﺘـﺪ ExecuteScalarﻣﺮﺑـﻮﻁ ﺑـﻪ ﺷـﻲﺀ SqlCommandﺍﺳـﺘﻔﺎﺩﻩ
ﻣﻲ ﮔﺮﺩﺩ.
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
8 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
;)(MyConnection.Open
;)(int intRes = (int)newCmd.ExecuteScalar
;)(MyConnection.Close
; )Response.Write(intRes
}
ﺩﺭ ﻓﺼﻞ ﻗﺒﻞ ﺑﺮﺍﻱ ﻣﺜﺎﻝ ﺑﺮﺍﻱ ﺍﻧﺘﺨﺎﺏ ﻛﺮﺩﻥ ﻳﻚ ﺳﺮﻱ ﺭﻛﻮﺭﺩ ﺍﺯ ﺩﻳﺘﺎﺑﻴﺲ ﺍﺯﺩﺳﺘﻮﺭﺍﺗﻲ ﻣﺎﻧﻨﺪ ﺯﻳﺮ ﺍﺳـﺘﻔﺎﺩﻩ
ﻣﻲ ﻛﺮﺩﻳﻢ :
;"'" strSQL = " select * from tbl1 where field1='"+ text1.text +
ﺑﻪ ﺟﺎﻱ ﺍﻳﻨﻜﻪ Text1.textﺭﺍ ﺑﺪﻳﻦ ﺻﻮﺭﺕ ﺑﻪ ﻋﺒﺎﺭﺕ ﭘﺎﺱ ﻛﻨﻴﻢ ﻣﻲ ﺗﻮﺍﻥ ﺍﺯ ﭘﺎﺭﺍﻣﺘﺮﻫﺎ ﻫﻢ ﺑﻪ ﺻـﻮﺭﺕ ﺯﻳـﺮ
ﺍﺳﺘﻔﺎﺩﻩ ﻧﻤﻮﺩ :
ﻣﺜﺎﻝ :٤
ﺩﺭ ﺍﻳﻦ ﻣﺜﺎﻝ ﻣﻲ ﺧﻮﺍﻫﻴﻢ ﺑﺎ ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺭﻭﺷﻲ ﻣﺘﻔﺎﻭﺕ ﻧﺴﺒﺖ ﺑﻪ ﻣﺜﺎﻝ ﻳﻚ ،ﻣﺤﺘﻮﻳﺎﺕ ﺗﻜﺴﺖ ﺑﺎﻛﺲ ﻫـﺎ ﺭﺍ
ﺍﻟﺒﺘﻪ ﺑﺮﺍﻱ ﻭﺭﻭﺩ ﺍﻃﻼﻋﺎﺕ ﺑﻪ ﺟﺪﻭﻝ myTestDB.dbo.tblEntry.IDﻣﻮﺭﺩ ﺑﺮﺭﺳﻲ ﻗﺮﺍﺭ ﺩﻫﻴﻢ.
ﻓﺮﻡ ﻭﺭﻭﺩ ﺍﻃﻼﻋﺎﺕ ﺭﺍ ﺑﻪ ﺷﻜﻞ ﺯﻳﺮ ﺁﻣﺎﺩﻩ ﻛﺮﺩﻩ ﻭ ﻧﺎﻡ ﺗﻜﺴﺖ ﺑﺎﻛﺲ ﻫﺎ ﺭﺍ ﺑﻪ ﻋﺒﺎﺭﺍﺗﻲ ﻣﻌﻨﺎ ﺩﺍﺭ ﺗﺒﺪﻳﻞ ﻧﻤﺎﻳﻴـﺪ
)ﺍﺯ ﺟﺪﻭﻟﻲ ﺑﺎ BorderSize=0ﻫﻢ ﻣﻲ ﺗـﻮﺍﻥ ﺑـﺮﺍﻱ ﻣﺮﺗـﺐ ﻛـﺮﺩﻥ ﻋﻨﺎﺻـﺮ ﺻـﻔﺤﻪ ﺍﺳـﺘﻔﺎﺩﻩ ﻛـﺮﺩ( ،ﺳـﭙﺲ
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
9 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﺭﺍ ﺑﻪ ﺗﻜﺴﺖ ﺑﺎﻛﺲ ﻫﺎ ﻣـﺮﺗﺒﻂ ﻧﻤﺎﻳﻴـﺪ ﻭ ﻳـﻚ ﺩﻛﻤـﻪ ﻫـﻢ ﺑـﺮﺍﻱ ﺍﺿـﺎﻓﻪ ﻛـﺮﺩﻥRequiredFieldValidators
.ﺍﻃﻼﻋﺎﺕ ﺑﻪ ﺩﻳﺘﺎﺑﻴﺲ ﺑﻪ ﺻﻔﺤﻪ ﺍﺿﺎﻓﻪ ﻧﻤﺎﻳﻴﺪ ﻭ ﻳﻚ ﺩﻳﺘﺎﮔﺮﻳﺪ ﺑﺮﺍﻱ ﻧﻤﺎﻳﺶ ﺁﻧﻬﺎ
sqlcommandEntry.Parameters.Add(
new SqlParameter("@Id", SqlDbType.Int));
sqlcommandEntry.Parameters["@Id"].Value = txtID.Text;
sqlcommandEntry.Parameters.Add(
new SqlParameter("@Entry_No", SqlDbType.Int));
sqlcommandEntry.Parameters["@Entry_No"].Value = txt_Entry_No.Text;
sqlcommandEntry.Connection.Open();
sqlcommandEntry.ExecuteNonQuery();
sqlcommandEntry.Connection.Close();
DataGrid1.DataSource=datasetEntry.Tables["tblEntry"].DefaultView;
DataGrid1.DataBind();
DataGrid1.Visible = true;
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
([email protected]) ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ: ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ
10 ASP.NET ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﻫﻤﺎﻧﻄﻮﺭ ﻛﻪ ﻣﻼﺣﻈﻪ ﻣﻲ ﻓﺮﻣﺎﻳﻴﺪ ﺍﻳﻦ ﺭﻭﺵ ﺷﺒﻴﻪ ﺑﻪ ﺭﻭﺷﻲ ﺍﺳﺖ ﻛﻪ ﺑﺮﺍﻱ ﺭﻭﻳﻪ ﻫﺎﻱ ﺫﺧﻴﺮﻩ ﺷﺪﻩ ﺍﻱ ﻛـﻪ
ﭘﺎﺭﺍﻣﺘﺮ ﻣﻲ ﮔﺮﻓﺘﻨﺪ ﺑﻜﺎﺭ ﻣﻲ ﺭﻭﺩ.
ﺑــﺮﺍﻱ ﺍﺳــﺘﻔﺎﺩﻩ ﺍﺯ ﺩﻳﺘــﺎﺑﻴﺲ ﻫــﺎﻱ OLE DBﻣﺎﻧﻨــﺪ ﺍﻛﺴــﺲ ﺩﺭ ADO.NETﺑﺎﻳــﺪ ﺍﺯ ﻓﻀــﺎﻱ ﻧــﺎﻡ
System.Data.OleDbﺍﺳﺘﻔﺎﺩﻩ ﻛﺮﺩ .ﺑـﺎ ﺍﺳـﺘﻔﺎﺩﻩ ﺍﺯ ﻛـﻼﺱ System.Data.OleDb.OleDbCommand
ﻣﻲ ﺗﻮﺍﻥ ﻳﻚ ﺳﺮﻱ ﺍﺯ ﺩﺳﺘﻮﺭﺍﺕ SQLﻣﺎﻧﻨﺪ Update ، Insert ، Selectﻭ Deleteﻭ ﻫﻤﭽﻨﻴﻦ ﺍﺟﺮﺍﻱ ﺭﻭﻳﻪ
ﻫﺎﻱ ﺫﺧﻴﺮﻩ ﺷﺪﻩ ﺭﺍ ﺍﻧﺠﺎﻡ ﺩﺍﺩ.
ﻣﺜﺎﻝ :٥
ﺩﺭ ﻣﺜﺎﻝ ﺯﻳﺮ ﻗﺼﺪ ﺩﺍﺭﻳﻢ ﻳﻚ ﺳﺮﻱ ﺍﺯ ﺍﻃﻼﻋﺎﺕ ﺭﺍ ﺩﺭﻭﻥ ﺑﺎﻧﻚ ﺍﻃﻼﻋﺎﺗﻲ ﺍﻛﺴﺲ ﺫﺧﻴﺮﻩ ﻛﻨﻴﻢ.
ﺍﺑﺘﺪﺍ ﺍﻛﺴﺲ XPﺭﺍ ﺑﺎﺯ ﻛﻨﻴﺪ ﻭ ﺳﭙﺲ ﺍﺯ ﻣﻨﻮﻱ ﻓﺎﻳﻞ ﮔﺰﻳﻨﻪ ﻱ Newﺭﺍ ﺍﻧﺘﺨﺎﺏ ﻛﻨﻴـﺪ ﻭ ﺍﺯ ﭘﻨـﻞ ﺳـﻤﺖ ﺭﺍﺳـﺖ
ﺻـﻔﺤﻪ ﺭﻭﻱ ﮔﺰﻳﻨـﻪ ﻱ Blank DataBaseﻛﻠﻴـﻚ ﻧﻤﺎﻳﻴـﺪ ﺗـﺎ ﻳـﻚ ﺑﺎﻧــﻚ ﺟﺪﻳـﺪ ﺧـﺎﻟﻲ ﺑـﺮﺍﻱ ﻣﺜـﺎﻝ ﺑـﻪ ﻧــﺎﻡ
access_db.mdbﺍﻳﺠﺎﺩ ﺷﻮﺩ .ﺩﺭ ﺻـﻔﺤﻪ ﻱ ﺩﻳـﺎﻟﻮﮒ ﺑـﺎﺯ ﺷـﺪﻩ )ﺷـﻜﻞ (٨ﺭﻭﻱ ﺁﻳـﺘﻢ Create Table in
design Viewﻛﻠﻴــﻚ ﻧﻤﺎﻳﻴــﺪ ﺗــﺎ ﺻــﻔﺤﻪ ﻱ ﻃﺮﺍﺣــﻲ ﺩﻳﺘــﺎﺑﻴﺲ ﻛــﻪ ﺷــﺒﻴﻪ ﻣﺤــﻴﻂ ﻃﺮﺍﺣــﻲ ﺩﻳﺘــﺎﺑﻴﺲ ﺩﺭ
SQL-Serverﺍﺳﺖ ﺑﺎﺯ ﺷﻮﺩ .ﺳﭙﺲ ﻣﻄﺎﺑﻖ ﺷﻜﻞ ﺯﻳﺮ )ﺷﻜﻞ (٩ﺟﺪﻭﻝ ﺭﺍ ﻃﺮﺍﺣـﻲ ﻛﻨﻴـﺪ .ﺳـﭙﺲ ﭘﻨﺠـﺮﻩ ﺭﺍ
ﺑﻨﺪﻳﺪ ﺗﺎ ﺻﻔﺤﻪ ﻱ ﺫﺧﻴﺮﻩ ﻛﺮﺩﻥ ﻧﺎﻡ ﺟﺪﻭﻝ )ﺷﻜﻞ ( ١٠ﻇـﺎﻫﺮ ﺷـﻮﺩ ﻭ ﻧـﺎﻡ tblEntryﺭﺍ ﻭﺍﺭﺩ ﻧﻤﺎﻳﻴـﺪ .ﺳـﭙﺲ
ﺍﻛﺴﺲ ﺍﺯ ﺷﻤﺎ ﺩﺭ ﻣﻮﺭﺩ ﺍﻳﺠﺎﺩ Primary keyﺳﻮﺍﻝ ﻣﻲ ﻛﻨﺪ )ﺷﻜﻞ .(١١
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
11 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
12 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﺁﻧﺮﺍ ﺗﺎﻳﻴﺪ ﻧﻜﻨﻴﺪ! ﭼﻮﻥ ﻳﻚ ﻓﻴﻠﺪ ﭘﻴﺶ ﻓﺮﺽ ﺩﺭﺳﺖ ﻣﻲ ﻛﻨﺪ )ﺍﻟﺒﺘﻪ ﺍﻳﻦ ﻣﻮﺿﻮﻉ ﺑﺴﺘﮕﻲ ﺑﻪ ﺩﻳﺘﺎﺑﻴﺲ ﺷـﻤﺎ ﻫـﻢ
ﺩﺍﺭﺩ .(...ﺑﺮﺍﻱ ﺩﺭﺳﺖ ﻛﺮﺩﻥ Primary keyﻫﻤﺎﻧﻨـﺪ SQL-Serverﻣـﻲ ﺗـﻮﺍﻥ ﻋﻤـﻞ ﻛـﺮﺩ )ﻳﻌﻨـﻲ ﺭﻭﻱ ﻓﻴﻠـﺪ
ﺩﻟﺨﻮﺍﻩ ﻣﻲ ﺗﻮﺍﻥ ﻛﻠﻴﻚ ﻛﺮﺩ ﻭ ﺳﭙﺲ ﺍﺯ ﻣﻨـﻮﻱ ﻇـﺎﻫﺮ ﺷـﺪﻩ ﮔﺰﻳﻨـﻪ ﻱ Primary keyﺭﺍ ﺍﻧﺘﺨـﺎﺏ ﻧﻤـﻮﺩ (.ﻳـﻚ
Primary keyﺭﻭﻱ ﻓﻴﻠﺪ IDﺩﺭﺳﺖ ﻛﻨﻴﺪ .ﻛﺎﺭ ﺧﻮﺩ ﺭﺍ ﺫﺧﻴﺮﻩ ﻛﻨﻴﺪ ﺗﺎ ﺍﺯ ﺍﻳﻦ ﺩﻳﺘﺎﺑﻴﺲ ﺍﻳﺠﺎﺩ ﺷﺪﻩ ﺩﺭ ﻣﺜﺎﻟﻬﺎﻱ
ﺑﻌﺪﻱ ﺍﺳﺘﻔﺎﺩﻩ ﻧﻤﺎﻳﻴﻢ .
ﻳﻚ ﭘﺮﻭﮊﻩ ﻱ ASP.NETﺩﻳﮕﺮ ﺑﺎﺯ ﻛﻨﻴﺪ ﻭ ﺳﭙﺲ ﺷﻜﻞ ﻇﺎﻫﺮﻱ ﺁﻧﺮﺍ ﻫﻤﺎﻧﻨﺪ ﻣﺜﺎﻝ ﻗﺒﻠﻲ ﻃﺮﺍﺣﻲ ﻧﻤﺎﻳﻴﺪ )ﺷﻜﻞ
. (١٢
ﺳﭙﺲ ﺑﺎ ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﻛﺪ ﺯﻳﺮ ﻣﻲ ﺗﻮﺍﻥ ﺭﻛﻮﺭﺩﻫﺎﻱ ﺟﺪﻳﺪ ﺭﺍ ﺑﻪ ﺁﻥ ﺍﺿﺎﻓﻪ ﻛﺮﺩ.
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
13 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
// Connect to Database
OleDbConnection cnAccess = new
OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;"+
"Data Source="+ FilePath );
cnAccess.Open();
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
([email protected]) ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ: ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ
14 ASP.NET ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
// displaying data
OleDbDataAdapter sqldataadapterEntry =
new OleDbDataAdapter("select * from tblEntry",cnAccess);
DataSet datasetEntry = new DataSet();
sqldataadapterEntry.Fill(datasetEntry, "tblEntry");
DataGrid1.DataSource=datasetEntry.Tables["tblEntry"].DefaultView;
DataGrid1.DataBind();
DataGrid1.Visible = true;
ﺍﻛﺴـﺲ ﺑـﻪmdb ﺑﺮﺍﻱ ﻣﺸـﺨﺺ ﻛـﺮﺩﻥ ﻣﺴـﻴﺮ ﻓﻴﺰﻳﻜـﻲ ﻓﺎﻳـﻞASP ﺩﺭ ﻣﺜﺎﻝ ﻓﻮﻕ ﺍﺯ ﻫﻤﺎﻥ ﺭﻭﺵ ﻗﺪﻳﻤﻲ
ﻫﻤﺎﻧﻄﻮﺭ ﻛﻪ ﻣﻼﺣﻈﻪ ﻣﻲ ﻓﺮﻣﺎﻳﻴﺪ ﻫﻤﻪ ﭼﻴـﺰ ﻣﺎﻧﻨـﺪ ﻗﺒـﻞ ﺍﺳـﺖ. ﺍﺳﺘﻔﺎﺩﻩ ﻛﺮﺩﻩ ﺍﻳﻢServer.MapPath ﺻﻮﺭﺕ
. ﻗﺮﺍﺭ ﮔﺮﻓﺘﻪ ﺍﺳﺖ ﻭ ﺗﻤﺎﻡ ﺗﻮﺿﻴﺤﺎﺕ ﺁﻧﻬﺎ ﻫﻢ ﺗﻜﺮﺍﺭﻱ ﻣﻲ ﺑﺎﺷﺪOleDb ﻋﺒﺎﺭﺕSql ﻓﻘﻂ ﺑﺠﺎﻱ
:٦ ﻣﺜﺎﻝ
: ﺭﻭﻱ ﻓﺮﻡ ﻗﺮﺍﺭ ﺩﻫﻴﺪ ﻭ ﺳﭙﺲ ﻓﻀﺎﻫﺎﻱ ﻧﺎﻡ ﺯﻳﺮ ﺭﺍ ﺑﻪ ﺑﺮﻧﺎﻣﻪ ﺍﺿﺎﻓﻪ ﻧﻤﺎﻳﻴﺪLabel ﻳﻚ
using System.Data.OleDb ;
using System.Text; // for StringBuilder
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
([email protected]) ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ: ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ
15 ASP.NET ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﻣﺮﺑﻮﻁ ﺑﻪ ﺑﺎﻧﻚ ﺍﻃﻼﻋﺎﺗﻲ ﺍﻛﺴﺲ ﺭﺍ ﻛﻪ ﺩﺭ ﻃﻲ ﻣﺜﺎﻝ ﻗﺒـﻞtblEntry ﻣﻲ ﺧﻮﺍﻫﻴﻢ ﺗﻚ ﺗﻚ ﺭﻛﻮﺭﺩﻫﺎﻱ ﺟﺪﻭﻝ
ﺍﻳﺠﺎﺩ ﻣﻲHTML ﺩﺭ ﺑﺮﻧﺎﻣﻪ ﺧﻮﺍﻧﺪﻩ ﻭ ﺁﻧﺮﺍ ﺩﺭ ﻳﻚ ﺟﺪﻭﻝ ﻛﻪ ﺧﻮﺩﻣﺎﻥ ﺑﺎ ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺗﮕﻬﺎﻱ، ﺍﻳﺠﺎﺩ ﻛﺮﺩﻩ ﺍﻳﻢ
. ﻧﻤﺎﻳﺶ ﺩﻫﻴﻢ، ﻛﻨﻴﻢ
ﺑـﻪ ﺍﻳـﻦ ﺟﻬـﺖ ﺩﺭ ﺑﺮﻧﺎﻣـﻪ ﺍﺳـﺘﻔﺎﺩﻩ ﻛـﺮﺩﻩ ﺍﻳـﻢ ﻛـﻪ ﻣـﻲ ﺧـﻮﺍﻫﻴﻢ ﺍﺯ ﻛـﻼﺱSystem.Text ﺍﺯ ﻓﻀﺎﻱ ﻧـﺎﻡ
ﺩﺭ ﻣـﻮﺭﺩ ﺟﻤـﻊ ﻛـﺮﺩﻥ+ ﺭﻭﺷـﻲ ﺷـﻴﻚ )!( ﻭ ﻛـﺎﺭﺁﺗﺮ ﻧﺴـﺒﺖ ﺑـﻪ ﻋﻼﻣـﺖ. ﺍﺳﺘﻔﺎﺩﻩ ﻧﻤـﺎﻳﻴﻢStringBuilder
. ﻫﺎ ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺍﻳﻦ ﻛﻼﺱ ﻣﻲ ﺑﺎ ﺷﺪ ﻛﻪ ﺩﺭ ﻣﺜﺎﻝ ﺯﻳﺮ ﺩﺭ ﻋﻤﻞ ﺑﻜﺎﺭ ﮔﺮﻓﺘﻪ ﺷﺪﻩ ﺍﺳﺖstring
// Connect to Database
OleDbConnection cnAccess = new
OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;"+
"Data Source="+ FilePath );
cnAccess.Open();
drEmp.Read();
sbResults.Append ("<Table>");
do
{
sbResults.Append ("<TR><TD>");
sbResults.Append ( drEmp.GetInt32(0).ToString());
sbResults.Append ("</TD><TD>");
sbResults.Append ( drEmp.GetInt32(1).ToString() );
sbResults.Append ("</TD><TR>");
}while (drEmp.Read());
sbResults.Append ("</Table>");
lblResult.Text = sbResults.ToString();
}
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
([email protected]) ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ: ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ
16 ASP.NET ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﻛﻼﺱ : OleDbDataAdapter
ﻫﻤﺎﻧﻄﻮﺭ ﻛﻪ ﺗﺎﺑﺤﺎﻝ ﻣﻼﺣﻈﻪ ﻛـﺮﺩﻩ ﺍﻳـﺪ Data Adapterﺑﻴـﺎﻧﮕﺮ ﺩﺳـﺘﻮﺭﺍﺕ ﻭ ﺍﺗﺼـﺎﻻﺗﻲ ﺍﺳـﺖ ﻛـﻪ ﺑـﺮﺍﻱ
ﭘﻴﻤﺎﻳﺶ ﺩﻳﺘﺎﺑﻴﺲ ﺑﻜﺎﺭ ﮔﺮﻓﺘﻪ ﻣﻲ ﺷﻮﺩ .ﺍﻳﻦ ﻛﻼﺱ ﺳﻪ ﺧﺎﺻـﻴﺖ ﺩﺳـﺘﻮﺭﻱ ﺩﺍﺭﺩ ﻛـﻪ ﺑـﺮﺍﻱ ﺑـﻪ ﺭﻭﺯ ﺭﺳـﺎﻧﻲ
ﺩﻳﺘﺎﺑﻴﺲ ﻣﻮﺭﺩ ﺍﺳﺘﻔﺎﺩﻩ ﻗﺮﺍﺭ ﻣﻲ ﮔﻴﺮﺩ:
: InsertCommandﺑﻴﺎﻧﮕﺮ ﭘﺮﺳﺠﻮ ﻳﺎ ﺭﻭﻳﻪ ﺫﺧﻴﺮﻩ ﺷﺪﻩ ﺍﻱ ﺍﺳﺖ ﻛﻪ ﺑﺮﺍﻱ ﺍﺿﺎﻓﻪ ﻛـﺮﺩﻥ ﺭﻛـﻮﺭﺩ ﺟﺪﻳـﺪ ﺑـﻪ
ﺩﻳﺘﺎﺑﻴﺲ ﺑﻜﺎﺭ ﺑﺮﺩﻩ ﻣﻲ ﺷﻮﺩ.
: SelectCommadﺑﻴﺎﻧﮕﺮ ﻳﻚ ﻋﺒـﺎﺭﺕ SQLﺍﺳـﺖ ﻛـﻪ ﺑـﺮﺍﻱ ﺍﻧﺘﺨـﺎﺏ ﺭﻛﻮﺭﺩﻫـﺎ ﺍﺯ ﺑﺎﻧـﻚ ﺍﻃﻼﻋـﺎﺗﻲ ﺑﻜـﺎﺭ
ﻣﻲ ﺭﻭﺩ.
: DeleteCommandﺑﻴﺎﻧﮕﺮ ﻳﻚ ﻋﺒﺎﺭﺕ SQLﺍﺳﺖ ﻛﻪ ﺑﺮﺍﻱ ﺣﺬﻑ ﺭﻛﻮﺭﺩﻫﺎ ﺍﺯ ﺩﻳﺘﺎﺳﺖ ﺑﻜﺎﺭ ﻣﻲ ﺭﻭﺩ.
DataSetﻛﻼﺳﻲ ﺍﺳﺖ ﻋﻤﻮﻣﻲ ﻛﻪ ﺑﻮﺳﻴﻠﻪ ﻱ .Net Frameworkﺗﻬﻴﻪ ﺷﺪﻩ ﺍﺳـﺖ .ﺍﻳـﻦ ﻛـﻼﺱ ﺑـﺮ ﺭﻭﻱ
ﺳﻤﺖ ﻛﻼﻳﻨﺖ ﺑﺮﺍﻱ ﺫﺧﻴﺮﻩ ﺳﺎﺯﻱ ﺩﺍﺩﻩ ﻫﺎ ﺑﻪ ﺭﻭﺷﻲ ﻛﻪ ﺑﺴﻴﺎﺭ ﻛﺎﺭﺑﺮﺩﻱ ﺗﺮ ﻭ ﻗﻮﻱ ﺗﺮ ﺍﺳﺖ ﻧﺴﺒﺖ ﺑﻪ ADO
Recordsetﻛﺎﺭﺑﺮﺩ ﺩﺍﺭﺩ .ﻋﻼﻭﻩ ﺑﺮ ﺍﻳﻦ ﺩﺍﺩﻩ ﻫﺎ ﺩﺭ DataSetﺑﻪ ﻓﺮﻣﺖ XMLﻣﻮﺟﻮﺩ ﺑﻮﺩﻩ ﻭ ﺑﻨﺎﺑﺮﺍﻳﻦ ﺑﺮﺍﻱ
ﺩﺳﺘﻴﺎﺑﻲ ﻭ ﻣﺪﻳﺮﻳﺖ ﺁﻣﺎﺩﻩ ﻣﻲ ﺑﺎﺷﻨﺪ .ﻓﺮﻣـﺖ XMLﺁﻧـﺮﺍ ﺑـﺮﺍﻱ ﻛﺎﺭﺑﺮﺩﻫـﺎﻱ ﻭﺏ ﺑﺴـﻴﺎﺭ ﻣﻨﺎﺳـﺐ ﺳـﺎﺧﺘﻪ ﻭ
ﺩﺳﺘﻴﺎﺑﻲ Cross-Platformﺭﺍ ﻣﻤﻜﻦ ﻣﻲ ﺳﺎﺯﺩ DataSet .ﻗﺎﺑﻠﻴﺖ ﺫﺧﻴﺮﻩ ﺳـﺎﺯﻱ ﺍﺯ ﭼﻨـﺪﻳﻦ ﺟـﺪﻭﻝ ﻭ ﺣﻔـﻆ
ﺍﺭﺗﺒﺎﻃﺎﺕ ﺑﻴﻦ ﺁﻧﻬﺎ ﺍﺳﺖ .ﺟﺪﺍﻭﻝ ﺩﺭ ﺍﺷﻴﺎﺀ DataTableﺫﺧﻴﺮﻩ ﻣﻲ ﺷﻮﻧﺪ ﻭ DataRelationﺑﻴﺎﻧﮕﺮ ﺍﺗﺒﺎﻃـﺎﺕ
ﺑﻴﻦ ﺟﺪﺍﻭﻝ ﺍﺳﺖ .ﺩﺭ ﺷﻲﺀ ﻫﺎﻱ DataRowﻭ DataColumnﺑﻪ ﺗﺮﺗﻴـﺐ ،ﺭﺩﻳـﻒ ﻫـﺎ ﻭ ﺳـﺘﻮﻥ ﻫـﺎ ﺩﺭ ﻳـﻚ
ﺟﺪﻭﻝ ﺫﺧﻴﺮﻩ ﻣﻲ ﺷﻮﻧﺪ )ﺷﻜﻞ .(١٣
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
17 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﻣﺜﺎﻝ :٧
ﻣﺜﺎﻟﻲ ﺩﺭ ﻣﻮﺭﺩ ﻧﺤﻮﻩ ﻱ ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺍﺷﻴﺎﺀ DataTableﻭ ﺭﻭﺍﺑﻂ ﺑﻴﻦ ﺁﻧﻬﺎ .
ﺩﺭ ﺍﻳﻦ ﻣﺜﺎﻝ ﻣﻲ ﺧﻮﺍﻫﻴﻢ ﻣﺜﺎﻝ ﻗﺒﻞ ﺭﺍ ﺑﺎ ﺍﺳﺘﻔﺎﺩﻩ ﺍﺯ ﺍﺷﻴﺎﺀ ﺫﻛﺮ ﺷﺪﻩ ﺩﺭ ﻗﻤﺴﺖ ﺟﺎﺭﻱ ﺑﺎﺯ ﻧﻮﻳﺴﻲ ﻛﻨﻴﻢ .
ﻳﻚ Labelﺭﻭﻱ ﻓﺮﻡ ﻗﺮﺍﺭ ﺩﻫﻴﺪ ﻭ ﺳﭙﺲ ﻓﻀﺎﻫﺎﻱ ﻧﺎﻡ ﺯﻳﺮ ﺭﺍ ﺑﻪ ﺑﺮﻧﺎﻣﻪ ﺍﺿﺎﻓﻪ ﻧﻤﺎﻳﻴﺪ :
; using System.Data.OleDb
using System.Text; // for StringBuilder
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
18 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
String FilePath;
FilePath = Server.MapPath("acess_db.mdb");
// Connect to Database
OleDbConnection cnAccess = new
OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;"+
"Data Source="+ FilePath );
cnAccess.Open();
// Fill the data with the output of the cmdSelect command. Note
// that the dataadapter is associated with the command. We use
// the dataadapter to fill the dataset.
daEmp.Fill(dsEmp, "tblEntry");
PrintRows(dsEmp);
}
private void PrintRows(DataSet myDataSet)
{
StringBuilder sbResult =new StringBuilder();
lblResult.Text = sbResult.ToString();
}
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
([email protected]) ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ: ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ
19 ASP.NET ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ
ﺷﺮﻛﺖ ﭘﻴﺸﮕﺎﻣﺎﻥ ﻓﻨﺎﻭﺭﻱ
ﺗﻤﺮﻳﻦ :
-١ﻣﺜﺎﻝ ٤ﺭﺍ ﻃﻮﺭﻱ ﺗﻐﻴﻴﺮ ﺩﻫﻴﺪ ﻛﻪ ﺑﺠﺎﻱ txtIDﻳﻚ Labelﻗﺮﺍﺭ ﮔﻴﺮﺩ ﻭ ﺑﺎ ﻫﺮ ﺑـﺎﺭ ﺍﺿـﺎﻓﻪ ﺷـﺪﻥ ﻳـﻚ
ﺁﻳﺘﻢ ﺑﻪ ﺩﻳﺘﺎﺑﻴﺲ ﻣﻘﺪﺍﺭ ﺁﻥ ﺑﻪ ﺻﻮﺭﺕ ﺧﻮﺩﻛﺎﺭ ﻳﻜﻲ ﺍﺿﺎﻓﻪ ﺷﻮﺩ .
New Post -٢ﻣﺮﺑﻮﻁ ﺑﻪ ﻓﻮﺭﻭﻡ ﺭﺍ ﺑﺎ ﺭﻭﻳﻪ ﻫﺎﻱ ﺫﺧﻴﺮﻩ ﺷﺪﻩ ﭘﻴﺎﺩﻩ ﺳﺎﺯﻱ ﻛﻨﻴﺪ.
-٣ﺩﺭ ﺟﺪﻭﻝ tblEntryﺩﻳﺘﺎﺑﻴﺲ MyTestDBﻛﻪ ﺩﺭ ﺍﻳﻦ ﻓﺼﻞ ﺍﻳﺠﺎﺩ ﺷﺪ ﻣﻴﺎﻧﮕﻴﻦ ﺩﺍﺩﻩ ﻫﺎﻱ ﻣﻮﺟﻮﺩ ﺩﺭ
ﻓﻴﻠﺪ Entry_Noﺭﺍ ﺭﻭﻱ ﺻﻔﺤﻪ ﻧﻤﺎﻳﺶ ﺩﻫﻴﺪ.
-٤ﺟﺪﻭﻝ tblAreaﻓﻮﺭﻭﻡ ﺭﺍ ﺑﺎ ﻓﻴﻠﺪﻫﺎﻳﻲ ﻣﺎﻧﻨﺪ ﻧﺎﻡ ﻭ ﺁﻱ ﺩﻱ ﺑﺨﺶ ﻭ ﺷﺮﺡ ﺑﺨﺶ ﺟﺪﻳﺪ ﺍﻳﺠﺎﺩ ﻧﻤـﻮﺩﻩ ﻭ
ﺳﭙﺲ ﻓﺮﻡ ﻭﺭﻭﺩ ﺩﺍﺩﻩ ﻫﺎﻱ ﺁﻧﺮﺍ ﺧﻠﻖ ﻧﻤﺎﻳﻴﺪ.
-٥ﺟﺪﻭﻝ tblPostsﻓﻮﺭﻭﻡ ﺭﺍ ﺑﺎ ﻓﻴﻠﺪﻫﺎﻳﻲ ﻣﺎﻧﻨﺪ ﻧﺎﻡ ﺷﺨﺺ ﭘﺴﺖ ﻛﻨﻨﺪﻩ ،ﻋﻨﻮﺍﻥ ﭘﺴﺖ ،ﻣﺤﺘﻮﺍﻱ ﭘﺴﺖ ،
ﺗﺎﺭﻳﺦ ﭘﺴﺖ ،ﺁﻱ ﺩﻱ ﺑﺨﺸﻲ ﻛـﻪ ﺩﺭ ﺁﻥ ﭘﺴـﺖ ﺍﻧﺠـﺎﻡ ﻣـﻲ ﺷـﻮﺩ ﺍﻳﺠـﺎﺩ ﻧﻤـﻮﺩﻩ ﻭ ﺳـﭙﺲ ﻓـﺮﻡ ﻭﺭﻭﺩ
ﺩﺍﺩﻩ ﻫﺎﻱ ﺁﻧﺮﺍ ﺧﻠﻖ ﻧﻤﺎﻳﻴﺪ.
ﻛﻠﻴﻪ ﺣﻘﻮﻕ ﺍﻳﻦ ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻣﺘﻌﻠﻖ ﺑﻪ ﺳﺎﻳﺖ ﺁﻣﻮﺯﺵ ﺍﻟﻜﺘﺮﻭﻧﻴﻜﻲ ﭘﺮﺷﻴﺎ ﻣﻴﺒﺎﺷﺪ
ﺍﺳﺘﺎﺩ ﺩﻭﺭﻩ :ﻭﺣﻴﺪ ﻧﺼﻴﺮﻱ )([email protected]
20 ﺟﺰﻭﻩ ﺁﻣﻮﺯﺷﻲ ﻛﻼﺱ ASP.NET