一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - java跟蹤執行的sql語句示例分享

java跟蹤執行的sql語句示例分享

2019-11-16 14:05java教程網 JAVA教程

這篇文章主要介紹了java跟蹤執行的sql語句示例分享,需要的朋友可以參考下

代碼:

復制代碼代碼如下:


package com.lwj.test.proxy;

 

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.sql.Connection;
import java.sql.SQLException;

public class DBManager {
    private final static ThreadLocal<Connection> conns = new ThreadLocal<Connection>();
    private static boolean show_sql = true;   

    public final static Connection getConnection() throws SQLException {   
        Connection conn = (Connection) conns.get();   
        if(conn ==null || conn.isClosed()){   
            // 這里使用我定義的一個簡單的 ConnectionProvider 替代 dataSource 獲取Connection   
            conn = ConnectionProvider.getConnection();   
            conns.set(conn);   
        }   
        return (show_sql && !Proxy.isProxyClass(conn.getClass()))?   
                      new _DebugConnection(conn).getConnection():conn;   
    }   

    /**  
     * 關閉連接  
     */  
    public final static void closeConnection() {   
        Connection conn = (Connection) conns.get();   
        try {   
            if(conn != null && !conn.isClosed()){   
                conn.setAutoCommit(true);   
                conn.close();   
            }   
        } catch (SQLException e) {   
        }   
        conns.set(null);   
    }   

    /**  
     * 用于跟蹤執行的SQL語句  
     */  
    static class _DebugConnection implements InvocationHandler {   
        private Connection conn = null;

        public _DebugConnection(Connection conn) {   
            this.conn = conn;
        }
        public Connection getConnection() {   
            return (Connection) Proxy.newProxyInstance(conn.getClass().getClassLoader(),new Class[]{Connection.class}, this);
        }
        public Object invoke(Object proxy, Method m, Object[] args) throws Throwable    
        {   
            try    
            {   
                String method = m.getName();   
                if("prepareStatement".equals(method) || "createStatement".equals(method))   
                {
                    System.out.println(method);
                    System.out.println(args[0]);
                }   
                return m.invoke(conn, args); 
            } catch (InvocationTargetException e) {   
                throw e.getTargetException();   
            }   
        }   
    } 
}

package com.lwj.test.proxy;

import java.sql.Connection;
import java.sql.DriverManager;

public class ConnectionProvider {
 public static Connection getConnection()   
    {
  Connection connection = null;
       try{   

           Class.forName("oracle.jdbc.OracleDriver").newInstance();   
           connection = DriverManager.getConnection("jdbc:oracle:thin:@192.168.1.101:1521:orcl", "scott", "tiger");
       }catch(Exception e){   
       }
       return connection;
    }
}

package com.lwj.test.proxy;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class TestMain {

 public static void main( String[] args )   
    {   
            Connection conn = null;   
            Statement stmt = null;
            PreparedStatement pstmt = null;
            try  
            {   
                conn = DBManager.getConnection();

                stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);   
                stmt.executeUpdate( "insert into test1(id,name,card,age,address) values(9,'liuwj','1234567890988777',24,'hubeitianmen')" );   

                /*pstmt = conn.prepareStatement( "insert into test1(id,name,card,age,address) values(?,?,?,?,?)"); 
                pstmt.setString(1, "10");
                pstmt.setString(2, "liuwj2");
                pstmt.setString(3, "1234567890988777");
                pstmt.setString(4, "22");
                pstmt.setString(5, "123456");
                pstmt.execute();*/
            }catch(SQLException e){   

            }finally{   
                 try{   
                   if( pstmt != null ){   
                    pstmt.close();   
                    pstmt = null;       
                   }   
                 }catch(SQLException e){   

                 }    

                 DBManager.closeConnection();   
            }     
    }
}

 

論壇上看到用下列語句:

復制代碼代碼如下:

pstmt = conn.prepareStatement( "insert into test1(id,name,card,age,address) values(?,?,?,?,?)"); 
pstmt.setString(1, "10");
pstmt.setString(2, "liuwj2");
pstmt.setString(3, "1234567890988777");
pstmt.setString(4, "22");
pstmt.setString(5, "123456");
pstmt.execute();

 

才能打印出sql語句

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 丰满岳乱妇在线观看视频国产 | 好涨好大我快受不了了视频网 | 日本视频二区 | 国产精品日本亚洲777 | 青青视频国产依人在线 | chinesespanking网站 | 香蕉91| 亚洲欧美日韩成人一区在线 | 亚洲欧美日韩国产一区二区精品 | 成人深夜视频 | 色天天综合色天天碰 | 9999热视频| 国产成人免费片在线视频观看 | 亚洲国产成人超福利久久精品 | 国产福利一区二区三区四区 | 亚洲麻豆精品 | 亚洲AV久久无码精品九九软件 | 手机看片1024日韩 | 91精品大神国产在线播放 | 天天摸天天操天天爽 | 99在线精品免费视频九九视 | 日韩欧美精品一区二区 | 91制片厂制作传媒破解版免费 | 狠狠综合久久综合网站 | 亚洲天堂视频在线观看 | 欧产日产国产精品专区 | 日韩精品一二三区 | 亚洲免费精品 | 久久热这里面只有精品 | 成人免费在线视频 | 精精国产www视频在线观看免费 | 欧美成人免费观看bbb | 国产精品99久久免费观看 | 大乳奶水bbw | 亚洲精品私拍国产福利在线 | 青青久在线视频免费观看 | 国产亚洲毛片在线 | 万域之王动漫在线观看全集免费播放 | 欧美福利在线观看 | 白丝美女同人18漫画 | 久久久久免费视频 |