html5中文学习网

您的位置: 首页 > 网络编程 > ASP.NET » 正文

C#.NET数据库操作记要_.NET教程_编程技术

[ ] 已经帮助:人解决问题
数据|数据库
一.数据库连接
将连接的数据库信息存在下面的文件中,方便统一管理。
Web.config//还不懂这个的。最好好好学学,本人觉得很有用,.NET么当然要用.NET的东西了。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<sectionGroup name="system.web">
<section name="database" type="System.Configuration.NameValueSectionHandler,System,Version=1.0.5000.0,Culture=neutral,PublicKeyToken=b77a5c561934e089" />
</sectionGroup>
</configSections>


<system.web>

<!-- ダイナミック デバッグ コンパイル
ASPX デバッグを有にするには、compilation debug="true" に定します。このを False に定すると、

このアプリケションの行のパフォマンスが向上します。

デバッグ シンボル (.pdb 情) をコンパイルされたペジに入するには、

compilation debug="true" に定します。この定によって、行速度のい大きなファイルが作成されます。

デバッグにのみ、このを true に定して、

それ以外のときは、常に false に定してください。については、

ASP .NET ファイルのデバッグ ドキュメントを参照してください。

-->
<compilation
defaultLanguage="c#"
debug="true"
>
<assemblies>
</assemblies>
</compilation>


<!-- カスタム エラ メッセジの定

カスタム エラ メッセジを有にするには customErrors mode="On"または "RemoteOnly" にします。にする合は "Off" に定します。

理する各エラに <error> タグを追加してください。
defaultRedirect="err.htm"

"オン" 常にカスタム (理解しやすい) メッセジを表示します。

"オフ" 常にな ASP.NET エラ情を表示します。

"リモトのみ" ロカル Web サバで行していないユザにしてのみ、

常にカスタム (理解しやすい) メッセジを表示します。この定は、セキュリティを考して、アプリケションのがリモトのクライアントに
表示されないようにする推された定です。

-->
<customErrors mode="RemoteOnly" defaultRedirect="/main/defaultError.aspx">
<error statusCode="404" redirect="/main/Error500.htm" />
<error statusCode="500" redirect="/main/Error500.htm"/>

</customErrors>



<!-- の定 '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
このセクションは、アプリケションのポリシを定します。使用できるモドは、"Windows"、

"Forms"、"Passport" および "None" です。


"None" が行されません。
"Windows" IIS はアプリケションの定にって (基本、ダイジェスト、または合 Windows)
を行します。匿名アクセスは IIS ではでなければなりません。

"Forms" ユザが格情を入力するカスタム フォム (Web ペジ) を提供してください。

そして、アプリケションでしてください。ユザの格情のトクンは Cookie に保存されています。

"Passport" は、一のログオンおよびメンバ サイトのコア プロファイル サビスを提供する
Microsoft により提供される管理サビスを使用して行されます。

-->
<identity impersonate="true"/>
<authentication mode="Windows" />
<!-- 限の定

このセクションは、アプリケションの限のポリシを定します。この定により、ユザまたはロルによるアプリケション リソスへのアクセスを可したり、

拒否したりできます。ワイルドカド : "*" は全を、"?" は匿名
(未) ユザを表します。

-->

<authorization>
<allow users="*" /> <!-- * 全ユザへの可 -->
<!-- <allow users="[ユザのコンマ区切り一]"
roles="[ロルのコンマ区切り一]"/>
<deny users="[ユザのコンマ区切り一]"
roles="[ロルのコンマ区切り一]"/>
-->
</authorization>

<!-- アプリケション レベルのトレス ログの定

アプリケション レベルのトレスは、アプリケション内の全ペジのトレス ログ出力を有にします。

アプリケション トレス ログを有にするには、trace enabled="true" に定します。pageOutput="true" に定された合、

トレス情が各ペジの下に表示されます。それ以外の合は、

Web アプリケション ルトから "trace.axd" ペジを参照してアプリケション トレスを

表示できます。

-->
<trace
enabled="false"
requestLimit="10"
pageOutput="false"
traceMode="SortByTime"
localOnly="true"
/>

<!-- セッション状の定

既定では、ASP.NET は Cookie を使用して、要求がどのセッションに属するかをします。

Cookie が使用できない合は、URL にセッション子を入力することで、セッションをつけることができます。

Cookie を有にするには、sessionState を cookieless="false" に定してください。

-->
<sessionState
mode="InProc"
stateConnectionString="tcpip=127.0.0.1:42424"
sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"
cookieless="false"
timeout="720"
/>

<!-- グロバリゼション
shift_jis このセクションはアプリケションのグロバリゼション定を行います。
utf-8-->
<globalization
requestEncoding="utf-8"
responseEncoding="utf-8"
/>

<database>
<!--add key="portaldb" value="server=(local)/NetSDK;database=portal;Integrated Security=SSPI" /-->
<add key="strConn" value="server=107.12.165.199;database=NWind;uid=NWind;pwd=NWind" />
</database>

</system.web>
<appSettings>
<add key="NWind" value="server=107.12.165.199;database=NWind;uid=NWind;pwd=NWind;" />
</appSettings>

</configuration>

连接代码:
using System.Data.SqlClient;
using System.Collections.Specialized;//操作xml所需要的namespace
string strConn=(String) ((NameValueCollection) Context.GetConfig("system.web/database"))["strConn"];

操作代码:
1,通过数据库中的存储过程来操作数据库,通过中间层来做工程是最理想的。能提高安全性和整体性能。
using (SqlConnection conn = new SqlConnection(strConn))
{
SqlCommand cmd = new SqlCommand("sp_SP",conn);
cmd.CommandType=CommandType.StoredProcedure;//声明是调用存储过程

cmd.Parameters.Add("@SNO",SqlDbType.VarChar,9);
cmd.Parameters.Add("@TD",SqlDbType.SmallDateTime);
cmd.Parameters.Add("@S_NOTE",SqlDbType.VarChar,100);//添加变量参数

cmd.Parameters["@SNO"].Value=SNO.Text;
cmd.Parameters["@TD"].Value=CheckBase.Text;
cmd.Parameters["@S_NOTE"].Value=SNote.Text;//给参数付值

conn.Open();
if(cmd.ExecuteNonQuery()!=0)//执行没有返回集合
OKMsg.Text="デタ登完成";
else
OKMsg.Text="デタ登失";
}


2,直接输出SQL语句

string strSQL="UPDATE NWind.NUser.DATA SET SNO='"+SNO.Text;//SQL Server需要指明该表所在的数据库名和创建该表的用户名
if(CheckBase.Text!="")
strSQL+="',MONTH ='"+CheckBase.Text+"/01";
strSQL+="' WHERE SNO ='"+SNO.Text+"'";
conn.Open();
SqlCommand cmd = new SqlCommand(strSQL,conn);
if(cmd.ExecuteNonQuery()!=0)
OKMsg.Text="デタが登しました";
else
OKMsg.Text="デタ登失";
}
3.检索语法SqlDataAdapter 与DataSet 联合使用,一般用于对获得数据集有特殊操作的情况
比较常用

private DataSet GetData()
{
string strConn=(String) ((NameValueCollection) Context.GetConfig("system.web/database"))["strConn"];
using (SqlConnection conn = new SqlConnection(strConn))
{
SqlCommand cmd = new SqlCommand("sp_CO",conn);
cmd.CommandType=CommandType.StoredProcedure;
cmd.Parameters.Add("@place",SqlDbType.VarChar,2);
cmd.Parameters["@place"].Value=Place.Text;
conn.Open();

SqlDataAdapter da = new SqlDataAdapter();
da.SelectCommand=cmd;
DataSet ds=new DataSet();
da.Fill(ds,"vCO");
//通过DataSet 你可以像对待一个本地数据库,可以存放多个数据表,实现你要达成的功能。具体如表格的处理有列的删除增加,多表之间的处理。等等
Count.Text="ヒット:"+ds.Tables["vCO"].Rows.Count.ToString()+"件";
return ds;
}

}

4,当仅仅用于读取数据的话推荐使用SqlDataReader ,读取速度较上面要快很多
private void DataLoader()
{
string strConn=(String) ((NameValueCollection) Context.GetConfig("system.web/database"))["strConn"];
using (SqlConnection conn = new SqlConnection(strConn))
{
SqlCommand cmd = new SqlCommand("sp_list",conn);
cmd.CommandType=CommandType.StoredProcedure;
cmd.Parameters.Add("@no",SqlDbType.VarChar,6);
cmd.Parameters["@no"].Value=NO.Text;
conn.Open();
using (SqlDataReader dr = cmd.ExecuteReader())
{
if(dr.Read())
{
C.Text=dr["C"].ToString(); //通过列名获得数据
M.Text=dr["MTC"].ToString(); //
}
else
OKMsg.Text="このデタがありません、又は定送り先のは法です。";
}

}

}
注意,以上都采用Using(),好处是不需要再给打开的数据库连接,作Close()操作了。
因为本人记性极差,所以很喜欢这个方法

先到这里吧。数据库中存储过程具体怎么做。以后再讲吧。


6KpHTML5中文学习网 - HTML5先行者学习网
6KpHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助