组装数据库

来源:互联网 发布:个性电脑桌面美化软件 编辑:程序博客网 时间:2024/04/29 00:24

组装数据库

文章 http://blog.csdn.net/xiaolangfanhua/article/details/52592859 中已经讲解了如何通过文件中的属性信息连接数据库,本文将讲解在连接数据库之后如何读取并执行SQL语句,下面介绍一下主要操作步骤:

1、连接数据库:
getConnection方法读取database.properties文件中的属性信息,并将属性jdbc.drivers 添加到系统属性中。驱动程序管理器使用属性jdbc.drivers 加载相应的驱动程序。getConnection 方法使用jdbc.url , jdbc.username , jdbc.password 等属性打开数据库连接。

2、使用SQL语句打开文件:
如果未提供任何文件名,则在控制台提示用户输入语句。

3、使用泛化的execute 方法执行每条语句:
如果它返回true ,则说明该语句产生了一个结果集。

4、处理结果集:
如果产生了结果集,则打印出结果。因为这是一个泛化的结果集,所以我们必须使用元数据来确定该结果的列数。

5、异常处理:
如果运行过程中出现SQL异常,则打印出这个异常以及所有包含在其中的与其链接在一起的相关异常。

6、关闭数据库连接

实例代码如下:

import java.nio.file.*;import java.sql.*; import java.io.*;import java.util.*;/** * 读取SQL语句文件,执行这些语句。 * 数据库组装 * @author Administrator * */public class ExecSQL {    public static void main(String[] args) throws IOException    {        try        {            Scanner in=(args.length==0? new Scanner(System.in) : new Scanner(Paths.get(args[0])));            try(Connection conn=TestDB.getConnection())            {                Statement stat=conn.createStatement();                while(true)                {                    if(args.length==0) System.out.println("Enter command or EXIT to exit:");                    if(!in.hasNext()) return;                    String line=in.nextLine();                    if(line.equals("EXIT")||line.equals("exit"))                     {                        in.close();                        return;                    }                    if(line.trim().endsWith(";"))                    {                        line=line.trim();                        line=line.substring(0,line.length()-1);                    }                    try                    {                        boolean isResult=stat.execute(line);                        if(isResult)                        {                            ResultSet rs=stat.getResultSet();                            showResultSet(rs);                        }                        else                        {                            int updateCount=stat.getUpdateCount();                            System.out.println(updateCount+"rows updated");                        }                    }catch(SQLException ex)                    {                        for(Throwable e:ex)                        {                            e.printStackTrace();                        }                    }                }            }        }catch(SQLException e)        {            for(Throwable t:e)            {                t.printStackTrace();            }        }    }    private static void showResultSet(ResultSet rs) throws SQLException {        ResultSetMetaData metaData=rs.getMetaData();        int columCount=metaData.getColumnCount();        for(int i=1;i<=columCount;i++)        {            if(i>1) System.out.print(", ");            System.out.print(metaData.getColumnLabel(i));        }        System.out.println();        while(rs.next())        {            for(int i=1;i<=columCount;i++)            {                if(i>1) System.out.print(", ");                System.out.print(rs.getString(i));            }            System.out.println();        }    }}

代码中 TestDB 是文章 http://blog.csdn.net/xiaolangfanhua/article/details/52592859 中实例代码中的类,是用于通过文件中的属性信息创建数据库连接的,其方法 getConnection() 返回一个数据库连接。

0 0
原创粉丝点击