@Test
public void createXls() throws Exception{
//声明一个工作薄
HSSFWorkbook wb = new HSSFWorkbook()
//声明表
HSSFSheet sheet = wb.createSheet("第一个表")
//声明行
HSSFRow row = sheet.createRow(7)
//声明列
HSSFCell cel = row.createCell(3)
//写入数据
cel.setCellValue("你也好")
FileOutputStream fileOut = new FileOutputStream("d:/a/b.xls")
wb.write(fileOut)
fileOut.close()
}
第二步:导出指定数据库的所有表
分析:
1:某个数数据库有多少表,表名是什么?―――DataBaseMetadate.getMetadate().getTables(null,null,null,new String[]{Table}) - excel的文件名称。
2:对每一个表进行select * *** 作。 - 每一个sheet的名称。
3:分析表结构,rs.getMetadate()ResultSetMedated
4:多个列,列名是什么.- 字段名就是sheet的第一行信息。
5:获取每一行的数据 – 放到sheet第一行以后。
@Test
public void export() throws Exception{
//声明需要导出的数据库
String dbName = "focus"
//声明book
HSSFWorkbook book = new HSSFWorkbook()
//获取Connection,获取db的元数据
Connection con = DataSourceUtils.getConn()
//声明statemen
Statement st = con.createStatement()
//st.execute("use "+dbName)
DatabaseMetaData dmd = con.getMetaData()
//获取数据库有多少表
ResultSet rs = dmd.getTables(dbName,dbName,null,new String[]{"TABLE"})
//获取所有表名 - 就是一个sheet
List<String>tables = new ArrayList<String>()
while(rs.next()){
String tableName = rs.getString("TABLE_NAME")
tables.add(tableName)
}
for(String tableName:tables){
HSSFSheet sheet = book.createSheet(tableName)
//声明sql
String sql = "select * from "+dbName+"."+tableName
//查询数据
rs = st.executeQuery(sql)
//根据查询的结果,分析结果集的元数据
ResultSetMetaData rsmd = rs.getMetaData()
//获取这个查询有多少行
int cols = rsmd.getColumnCount()
//获取所有列名
//创建第一行
HSSFRow row = sheet.createRow(0)
for(int i=0i<colsi++){
String colName = rsmd.getColumnName(i+1)
//创建一个新的列
HSSFCell cell = row.createCell(i)
//写入列名
cell.setCellValue(colName)
}
//遍历数据
int index = 1
while(rs.next()){
row = sheet.createRow(index++)
//声明列
for(int i=0i<colsi++){
String val = rs.getString(i+1)
//声明列
HSSFCell cel = row.createCell(i)
//放数据
cel.setCellValue(val)
}
}
}
con.close()
book.write(new FileOutputStream("d:/a/"+dbName+".xls"))
}
MySql导出数据库的命令如下:Sql代码
mysqldump -uusername -ppassword -hhost -Pport exportDatabaseName >exportPath
mysqldump -uusername -ppassword -hhost -Pport exportDatabaseName >exportPath
利用Java调用命令窗口执行命令来进行MySql导入数据库一般分三步走:
第一步:登录Mysql数据库,在登录数据库的时候也可以指定登录到哪个数据库,如果指定了则可以跳过第二步;
第二步:切换数据库到需要导入的目标数据库
第三步:利用命令开始导入
在进行导出的时候,需要注意命令语句的运行环境,如果已经将mysql安装路径下的bin加入到
系统的path变量中,那么在导出的时候可以直接使用命令语句,否则,就需要在执行命令语句的
时候加上命令所在位置的路径,即mysql安装路径想的bin下的mysqldump命令。
首先导入 mysql-connector-java-5.1.45-bin.jar 包
代码如下:
import java.io.*import java.sql.*
public class App {
public static void main(String[] args) {
try {
Class.forName("com.mysql.jdbc.Driver")
// 数据库用户
String user = "root"
// 数据库密码
String password = ""
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db_sale", user, password)
Statement stmt = conn.createStatement()
// 查询 , 从数据库 db_sale 的 product 表中查询 id, name, qty 字段
ResultSet rs = stmt.executeQuery("SELECT id, name, qty FROM product")
// 创建输出文件 result.txt
File file = new File("d://result.txt")
OutputStreamWriter writer = new OutputStreamWriter(new FileOutputStream(file))
while (rs.next()) {
writer.write(String.valueOf(rs.getLong(1)) + "\t")
writer.write(rs.getString(2) + "\t")
writer.write(String.valueOf(rs.getInt(3)))
writer.write("\r\n")
//System.out.println(rs.getLong(1))
//System.out.println(rs.getString(2))
//System.out.println(rs.getLong(3))
}
writer.flush()
writer.close()
rs.close()
stmt.close()
conn.close()
} catch (Exception e) {
e.printStackTrace()
}
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)