乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > 如何将Excel表导入现有的SQL SEVER数据表里面-excel导入sqlserver c,将excel导入sql数

如何将Excel表导入现有的SQL SEVER数据表里面-excel导入sqlserver c,将excel导入sql数

作者:乔山办公网日期:

返回目录:excel表格制作


一、在EXCEL中 新建一列,如把列名定为ab,下面放你的数据,比如1,2,3……

二、打开SQL企业管理器,右击你所需要导入的数据库,选择导入数据,下一步,数据源选择Microsoft Eccel 97-2000,选择excel文件继续下一步,往下按,选择Sheet1$或者2,3 看你把数据放在那一页,点转换可以根据你自己需要设置一些字段属性,目的里改一下表的名字(如果是要往已存在的表里插数据,应该要选择往目的表中追加数据,但字段名应该要一样,如果是添加新建表,选择创建目的表),新建表的话,表名自己随便写什么好了,容易记就好。设置完了就点下一步就导入了。当然可以先预览一下。

如果不熟悉,建议还是添加新建表吧,再用insert语句把导入的数据插入到你所需要插入的表里。

1、首先进入到sqlserver应用程序的操作页面中,鼠标右键单击想要放入Excel表格的数据库。

2、接下来需要点击任务,再点击任务中的导入数据选项,

3、接下来就会出现如下方图片长的页面,点击进行下一步。

4、接下来就需要在新出现的界面中,根据要求选择数据源 Excel,文件路径,以及Excel版本,进行下一步。

5、然后是目标数据库。选择“ msslserver”作为目标,无需更改服务器名称,输入对应的密码进行认证,选择对应的数据库作为数据库,最后单击“下一步”,如图所示。

6、所示界面中的默认选项就足够了。点击下一步。

7、图形界面,可以自定义目标数据库(该表可能不存在于数据库中),

8、单击预览以查看导入后的表状态,如图所示。

9、接下来在新出现的页面中,进行下一步。

10、最后,单击“完成”以成功导入。


使用sqlserver的导入功能。
sqlserver2008系统,登录ssms,在数据库copy上右健,任务-->导入,可以打开导入的引导界面。

如果只是一个表的数据,也可以在excel上复制数据,然后在ssms里打开表,粘贴数据。

最近在一个项目中需要用到Excel文件导入数7a64e78988e69d83339据库的功能,本人很懒,所以到网上搜了一堆方法,但是通过对比,觉得一下三种是比较好用或者不是很常见的方法,希望对大家有所帮助。

方案一: 通过OleDB方式获取Excel文件的数据,然后通过DataSet中转到SQL Server,这种方法的优点是非常的灵活,可以对Excel表中的各个单元格进行用户所需的操作。

openFileDialog = new OpenFileDialog();  
openFileDialog.Filter = "Excel files(*.xls)|*.xls";  
 
if(openFileDialog.ShowDialog()==DialogResult.OK)  
{  
    FileInfo fileInfo = new FileInfo(openFileDialog.FileName);  
    string filePath = fileInfo.FullName;  
    string connExcel = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties=Excel 8.0";  
      
    try 
    {  
        OleDbConnection oleDbConnection = new OleDbConnection(connExcel);  
        oleDbConnection.Open();  
          
        //获取excel表  
        DataTable dataTable = oleDbConnection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);  
 
        //获取sheet名,其中[0][1]...[N]: 按名称排列的表单元素  
        string tableName = dataTable.Rows[0][2].ToString().Trim();  
        tableName = "[" + tableName.Replace("'","") + "]";  
 
        //利用SQL语句从Excel文件里获取数据  
        //string query = "SELECT classDate,classPlace,classTeacher,classTitle,classID FROM " + tableName;  
        string query = "SELECT 日期,开课城市,讲师,课程名称,持续时间 FROM " + tableName;  
        dataSet = new DataSet();  
 
        //OleDbCommand oleCommand = new OleDbCommand(query, oleDbConnection);  
        //OleDbDataAdapter oleAdapter = new OleDbDataAdapter(oleCommand);  
        OleDbDataAdapter oleAdapter = new OleDbDataAdapter(query,connExcel);  
        oleAdapter.Fill(dataSet,"gch_Class_Info");  
        //从excel文件获得数据后,插入记录到SQL Server的数据表
        DataTable dataTable1 = new DataTable();  
          
        SqlDataAdapter sqlDA1 = new SqlDataAdapter(@"SELECT classID, classDate,  
classPlace, classTeacher, classTitle, durativeDate FROM gch_Class_Info",sqlConnection1);  
          
        //SqlCommandBuilder sqlCB1 = new SqlCommandBuilder(sqlDA1);  
          
        sqlDA1.Fill(dataTable1);  
 
        foreach(DataRow dataRow in dataSet.Tables["gch_Class_Info"].Rows)  
        {  
            DataRow dataRow1 = dataTable1.NewRow();  
              
            dataRow1["classDate"] = dataRow["日期"];  
            dataRow1["classPlace"] = dataRow["开课城市"];  
            dataRow1["classTeacher"] = dataRow["讲师"];  
            dataRow1["classTitle"] = dataRow["课程名称"];  
            dataRow1["durativeDate"] = dataRow["持续时间"];  
 
            dataTable1.Rows.Add(dataRow1);  
        }  
 
        Console.WriteLine("新插入 " + dataTable1.Rows.Count.ToString() + " 条记录");  
        sqlDA1.Update(dataTable1);  
          
        oleDbConnection.Close();  
 
    }  
    catch(Exception ex)  
    {  
        Console.WriteLine(ex.ToString());  
    }  
}

方案二: 直接通过SQL语句执行SQL Server的功能函数将Excel文件转换到SQL Server数据库。

OpenFileDialog openFileDialog = new OpenFileDialog();  
openFileDialog.Filter = "Excel files(*.xls)|*.xls";  
 
SqlConnection sqlConnection1 = null;  
 
if(openFileDialog.ShowDialog()==DialogResult.OK)  
{  
    string filePath = openFileDialog.FileName;  
 
    sqlConnection1 = new SqlConnection();  
    sqlConnection1.ConnectionString = "server=(local);integrated security=SSPI;initial catalog=Library";  
 
    //import excel into SQL Server 2000  
    /*string importSQL = "SELECT * into live41 FROM OpenDataSource" + 
        "('Microsoft.Jet.OLEDB.4.0','Data Source=" + "\"" + "E:\\022n.xls" + "\"" +   
        "; User ID=;Password=; Extended properties=Excel 5.0')...[Sheet1$]";*/ 
 
    //export SQL Server 2000 into excel  
    string exportSQL = @"EXEC master..xp_cmdshell  
'bcp Library.dbo.live41 out " + filePath + "-c -q -S" + "\"" + "\"" +  
        " -U" + "\"" + "\"" + " -P" + "\"" + "\"" + "\'";  
      
    try 
    {  
        sqlConnection1.Open();  
          
        //SqlCommand sqlCommand1 = new SqlCommand();  
        //sqlCommand1.Connection = sqlConnection1;  
        //sqlCommand1.CommandText = importSQL;  
        //sqlCommand1.ExecuteNonQuery();  
        //MessageBox.Show("import finish!");  
          
        SqlCommand sqlCommand2 = new SqlCommand();  
        sqlCommand2.Connection = sqlConnection1;  
        sqlCommand2.CommandText = exportSQL;  
        sqlCommand2.ExecuteNonQuery();  
        MessageBox.Show("export finish!");  
    }  
    catch(Exception ex)  
    {  
        MessageBox.Show(ex.ToString());  
    }  
}  
 
if(sqlConnection1!=null)  
{  
    sqlConnection1.Close();  
    sqlConnection1 = null;  
}

方案三: 通过到入Excel的VBA dll,通过VBA接口获取Excel数据到DataSet

OpenFileDialog openFile = new OpenFileDialog();  
openFile.Filter = "Excel files(*.xls)|*.xls";  
 
ExcelIO excelio = new ExcelIO();  
 
if(openFile.ShowDialog()==DialogResult.OK)  
{  
    if(excelio!=null)  
        excelio.Close();  
 
    excelio = new ExcelIO(openFile.FileName);  
    object[,] range = excelio.GetRange();  
    excelio.Close();  
 
      
    DataSet ds = new DataSet("xlsRange");  
 
    int x = range.GetLength(0);  
    int y = range.GetLength(1);  
 
    DataTable dt = new DataTable("xlsTable");  
    DataRow dr;  
    DataColumn dc;  
      
    ds.Tables.Add(dt);  
 
    for(int c=1; c<=y; c++)  
    {  
        dc = new DataColumn();  
        dt.Columns.Add(dc);  
    }  
      
    object[] temp = new object[y];  
      
    for(int i=1; i<=x; i++)  
    {  
        dr = dt.NewRow();  
 
        for(int j=1; j<=y; j++)  
        {  
            temp[j-1] = range[i,j];  
        }  
          
        dr.ItemArray = temp;  
        ds.Tables[0].Rows.Add(dr);  
    }  
 
    dataGrid1.SetDataBinding(ds,"xlsTable");  
      
    if(excelio!=null)  
        excelio.Close();  
}

当然还有其他一些方法,如遍历Excel文件中的数据然后构造sql语句,直接利用sql操作Excel文件导入数据库等,这些都是很常见的方法,因此就不再做收录了。最后说明下,以上的方法是我从网上找的源码并做了一定的修改。

相关阅读

关键词不能为空

ppt怎么做_excel表格制作_office365_word文档_365办公网