public void MultiInsertData(DataSet ds)
{
string connt = "Oracle的连接字符串";
string sql = "select id,name,… from tablename";必须与ds中的一致
DataTable dt = dsDefaults[0];
OracleConnection conn = new OracleConnection(connstr);
OracleCommand cmd = new OracleCommand(sql, conn);
connOpen();
OracleDataAdapter da = new OracleDataAdapter(sqlcmd);
OracleCommandBuilder cb = new OracleCommandBuilder(sqlda);
daUpdate(dt);
connClose();
sqlconnDispose();
}
用这个批量进行导入,速度快,而且方便呀
那你直接用Excel导入oracle数据库咯。
我那时50多个字段也还是insert语句实现的,那个Excel有200000条数据,就是循环了一分多钟都insert进去了。
如何将数据批量导入Oracle数据库?先确保你要导入的数据库SID中有和你导出数据时所用的用户和密码如果没有请看 2),
1)进入命令控制台,
输入:
imp username/password@SID file=/pathURL full=y
其中username为用户名,password为密码,pathURL导出数据所在路径,
如:
impr scott/tiger@orcl file=D:\datadmp
需要注意的是,你要导入的表的表空间所属的用户和密码必须和你要导入到的表空间所属的用户和密码相同,就是你导出数据时用的哪个用户,导入时也用哪个用户,
2)
如果没有这个用户,创建用户命令如下:
以sysdba 进入sqlplus,
create user identified by password;
grant dba to user;
如何将excel数据批量导入sql数据库
请参阅
将EXCEL数据表导入到SQL中
:jingyanbaidu/article/358570f66145a6ce4724fcba
如何将excel的数据导入到oracle数据库导入Excel表格
1创建表,表的字段与要导入文件的名称一致
2点击 工具---->ODBC导入器
3选择Excel file 点击连接
4选择要导入的文件,点击确定
5点击 到Oracle 在所有者中选择到自己之前创建的表格 按下回车键
查看对应的字段名是否相对应 最后单击导入
如何将一个txt文档的数据批量导入到数据库?编写和执行存贮过程:
CREATE PROCEDURE IMPORTTXT
@DBNAME VARCHAR(100)--数据库名
AS
DECLARE @SQLSTRING NVARCHAR(1000)
Set @SqlString=N'Masterxp_CmdShell ''bcp '+@dbname+'DBOTABLENAME in C:\CSVFILETXT -c -S'+@@servername+' -USA -P'''
execute sp_executesql @SqlString
GO
该过程将C:\CSVFILETXT 导入到TABLENAME表中,要求字段结构相符。TXT文档要求是以制表符为字段间隔符,换行为记录间隔。可以直接使用EXCEL导出的“以制表符分隔的文本文档”,或将文本文档转换成该格式。
转载:如何将Excel数据批量导入SQL数据库namespace WindowsApplication2{public partial class Form1 : Form{public Form1(){InitializeComponent();}private void button1_Click(object sender, EventArgs e){测试,将excel中的sheet1导入到sqlserver中
string connString = server=localhost;uid=sa;pwd=sqlgis;database=master;
SystemWindowsFormsOpenFileDialog fd = new OpenFileDialog();
if (fdShowDialog() == DialogResultOK){TransferData(fdFileName, sheet1″, connString);}}public void TransferData(string excelFile, string sheetName, string connectionString){DataSet ds = new DataSet();try{获取全部数据
string strConn = Provider=MicrosoftJetOLEDB40; + Data Source= + excelFile + ; + Extended Properties=Excel 80;;
OleDbConnection conn = new OleDbConnection(strConn);
connOpen();
string strExcel = ;
OleDbDataAdapter myCommand = null;
strExcel = stringFormat(select from [{0}$], sheetName);
myCommand = new OleDbDataAdapter(strExcel, strConn);
myCommandFill(ds, sheetName);
如果目标表不存在则创建
string strSql = stringFormat(if object_id(’{0}’) is null create table {0}(, sheetName);
foreach (SystemDataDataColumn c in dsTables[0]Columns){strSql += stringFormat([{0}] varchar(255),, cColumnName);}strSql = strSqlTrim(’,') + );
using (SystemDataSqlClientSqlConnection sqlconn = new SystemDataSqlClientSqlConnection(connectionString)){sqlconnOpen();
SystemDataSqlClientSqlCommand mand = sqlconnCreateCommand();
mandCommandText = strSql;
mandExecuteNonQuery();
sqlconnClose();}用bcp导入数据
using (SystemDataSqlClientSqlBulkCopy bcp = new SystemDataSqlClientSqlBulkCopy(connectionString)){bcpSqlRowsCopied += new SystemDataSqlClientSqlRowsCopiedEventHandler(bcp_SqlRowsCopied);
bcpBatchSize = 100;每次传输的行数
bcpNotifyAfter = 100;进度提示的行数
bcpDestinationTableName = sheetName;目标表
thisUpdate();}}}上面的TransferData基本可以直接使用,如果要考虑周全的话,可以用oledb来获取excel的表结构,并且加入ColumnMappings来设置对照字段,这样效果就完全可以做到和sqlserver的dts相同的效果了。
MySql数据库 :
优点: 1支持5000万条记录的数据仓库
2适应于所有的平台
3是开源软件,版本更新较快
4性能很出色。纯粹就性能而言,MySQL是相当出色的,因为它包含一个缺省桌面格式MyISAM。MyISAM数据库 与磁盘非常地兼容而不占用过多的CPU和内存。MySQL可以运行于Windows 系统而不会发生冲突,在UNIX或类似UNIX系统上运行则更好。你还可以通过使用64位处理器来获取额外的一些性能。因为MySQL在内部里很多时候都使用64位的整数处理。
5价格便宜
缺点: 缺乏一些存储程序的功能,比如MyISAM引擎联支持交换功能
MsSqlserver数据库:
优点: 1真正的客户机/服务器体系结构
2图形化的用户界面,使系统管理和数据库管理更加直观、简单
3丰富的编程接口工具,为用户进行程序设计提供了更大的选择余地
4与WinNT完全集成,利用了NT的许多功能,如发送和接受消息,管理登录安全性等,SQL Server也可以很好地与Microsoft BackOffice产品集成。
5有很好的伸缩性,可以跨平台使用。
6提供数据仓库功能,这个功能只在Oracle和其他 昂贵的DBMS中才有。
Oracle数据库:
优点: 1Oracle的稳定性要比Sql server好。
2Oracle在导数据工具sqlloadexe功能比Sqlserver的Bcp功能强大,Oracle可以按照条件把文本文件数据导入
3Oracle的安全机制比Sql server好。
4Sql server的易用性和友好性方面要比Oracle好。
5在处理大数据方面Oracle会更稳定一些。
6Sql Server在数据导出方面功能更强一些。
7处理速度方面比Oracle快一些,和两者的协议有关
缺点: 价格昂贵
以上就是关于c#如何将dataset中的数据批量导入oracle数据库全部的内容,包括:c#如何将dataset中的数据批量导入oracle数据库、MYSQL sqlserver oracle 之间的优缺点、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)