这里就拷用。NET2003的.cs源码:网上的代码由本人稍加整理而成
public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.HtmlControls.HtmlInputFile upName;//这里是上传控件的名字为upName
protected System.Web.UI.WebControls.Button Button1;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Button1.Click += new System.EventHandler(this.Button1_Click);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
private void Button1_Click(object sender, System.EventArgs e)
{
string fPath=this.upName.PostedFile.FileName;//获得要导入的文本文件
string extName=fPath.Substring(fPath.LastIndexOf(\".\")+1);//获得文件的扩展名
SqlConnection con=new SqlConnection(\"server=.;database=WitKey;uid=sa;pwd=accp.includein;\");//数据库连接对象,注意这里的SA是代表一种权限的,不然后面的BULK INSERT批量插入是不行的,
con.Open();
try
{
//SqlCommand com=new SqlCommand(\"BULK INSERT WitKey.dbo.txtInsert FROM \'\"+fPath+\"\' WITH (FIELDTERMINATOR = \',\',ROWTERMINATOR= \'\\n\')\",con);
SqlCommand com=new SqlCommand (\"BULK INSERT WitKey.dbo.test1 FROM \'\"+fPath+\"\' WITH ( FIELDTERMINATOR = \',\', ROWTERMINATOR =\'\\n\' )\",con );//这里的test1是代表要插入的表名,witkey代表要插入的数库名,最好数据字段类型默认为varchar,列数量相同
//其中的FIELDTERMINATOR=\',\'指明字段间所使用的分隔符为逗号
//其中ROWTERMINATOR= \'\\n\'指明记录间所使用的分隔符为回车
com.ExecuteNonQuery();
Response.Write(\"<script language=javascript>alert(\'数据导入成功!\')</script>\");
}
catch (SqlException SQLexc)
{
Response.Write(\"导入数据库时出错:\" + SQLexc.ToString());
}
con.Close();
}
} |