infobright 导入 导出
- 这句必须先执行:
SET SQL_LOG_BIN = 0;
全局修改:使用global修饰符(set global sql_log_bin=0) 版本低得无法用。
- 从服务器导入:这里导出只能导出到服务器上,不会在本地。如果数据库装在linux服务器,输出文件名目录要用"/tmp/xxx.csv", 然后去服务器对应目录找即可。
存在了数据库服务器上:
select * from channel_profile limit 13
into outfile '/tmp/channelProfile.zhibin'
CHARACTER SET utf8
fields terminated by ',' optionally enclosed by '"'
escaped by '"' lines terminated by '\n'
select * into outfile 'mydata.cvs' fields terminated by ',' from table1;
LOAD DATA INFILE '/tmp/channelProfile.zhibin' ignore into table channel_profile
CHARACTER SET utf8
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY '\n'
load data LOCAL infile 'mydata.cvs' into table table2 fields terminated by ',';
加上LOCAL, 会从本地导入。否则是数据库服务器上的路径。
- 默认导入导出的目录
是服务器上的:/usr/local/infobright-4.0.7-x86_64/data/statistics/mydata.cvs
其中statistics是数据库名称。
如果是mysql,导出目录是/var/lib/mysql/statisticsystem/+ mydata.cvs。任何你写的windows目录都会变成文件名。
- 可以从本地导入到远程:
LOAD DATA LOCAL INFILE 'D:/play_20170110.csv' into table log_play_2017_test FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY '\n';
;
select count(*) from log_play_2017_test
where request_time >=unix_timestamp("2017-01-10")
and request_time < unix_timestamp("2017-01-11")
;
当写在JDBC时,必须用\\ 替换上面的\, 因为是写在java的String字符串中,如\n需要替换成 \\n。
@PersistenceContext(unitName = "statLog") private EntityManager em; @Transactional public boolean importtest() { em.createNativeQuery(" SET SQL_LOG_BIN = 0 ").executeUpdate(); String sql = " LOAD DATA INFILE '/tmp/mydata.csv' ignore into table test_table" + " CHARACTER SET utf8 FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '\"' LINES TERMINATED BY '\\n' "; ; logger.info(sql); int num=0; num= emStatLog.createNativeQuery(sql).executeUpdate(); output("import result: the number of lines is " + num); output("Import success!"); return true; }
jpa不能执行 select * from xxx into outfile test.csv, 只能用jdbc的方式。从hibernate取到jdbc session示例:
@PersistenceContext(unitName = "primary") private EntityManager em; public void export() { //到处profile // filepath = filepath.replace('\\', '/');
//escaped by '\"' 这个会导致字段是null时,输出 ,"N,"xxxx" 到处是坑啊
String sql="select * from channel_profile into outfile '/tmp/test.csv' fields terminated by ',' optionally enclosed by '\"' lines terminated by '\\n'";
logger.info(sql); Session session = em.unwrap(org.hibernate.Session.class); session.doWork( new Work() { @Override public void execute(Connection con) throws SQLException { try ( PreparedStatement ps = con.prepareStatement( sql) ) { ps.execute(); } catch (Exception e) { e.printStackTrace(); } } } ); }
pom.xml添加:
<!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-core -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>5.1.4.Final</version>
<scope>provided</scope> <!-- 只是在编译时候用hibernate jar包。执行时候不要hibernate jar包。 -->
</dependency>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?