2019-08-25

jdbc連接數(shù)據(jù)庫办成,并封裝成數(shù)據(jù)庫工具類


import java.io.BufferedOutputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Properties;
import java.util.Vector;

import server.bean.Book;

public class DBTools {
    private static String driver;
    private static String url;
    private static String user;
    private static String password;
    private static InputStream is;
    private static Connection conn;

    static {
        Properties pt = new Properties();
        is = DBTools.class.getClassLoader().getResourceAsStream("jdbc.properties");
        try {
            pt.load(is);
            driver = pt.getProperty("driver");
            url = pt.getProperty("url");
            user = pt.getProperty("user");
            password = pt.getProperty("password");
            IOUtils.close(is);
        } catch (IOException e) {
            IOUtils.close(is);
            log("/n讀取數(shù)據(jù)庫配置文件失敗/n " + e);
        }
    }

    // log
    public static void log(String str) {
        DateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
        String time = df.format(System.currentTimeMillis());
        str = time + "  " + str;
        FileOutputStream fos = null;
        BufferedOutputStream bos = null;
        try {
            fos = new FileOutputStream("DBErroLog.txt");
            bos = new BufferedOutputStream(fos);
            byte[] b = str.getBytes();
            bos.write(b);
            bos.flush();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            IOUtils.close(fos, bos);
        }
    }

    // 獲取連接
    public static Connection getConnection() {
        try {
            Class.forName(driver);
            conn = DriverManager.getConnection(url, user, password);
            return conn;
        } catch (ClassNotFoundException e) {
            log("加載驅(qū)動失敗搓逾,沒有找到類!!澎粟!\n" + e);
        } catch (SQLException e) {
            e.printStackTrace();
            log("數(shù)據(jù)庫連接失敗,請檢查ip地址,端口號,賬號及密碼是否有誤H岜啤!割岛!\n" + e);
        }
        return null;
    }

    // 登錄驗證 SELECT NAME,pwd,is_manager FROM usr WHERE NAME='tan' AND
    // pwd='123456';
    public static int loginCheck(String usr, String pwd) throws SQLException {
        String sql = " SELECT is_manager FROM usr WHERE name=? AND pwd=?;";
        PreparedStatement ps = getConnection().prepareStatement(sql);
        ps.setString(1, usr);
        ps.setString(2, pwd);
        ResultSet rs = ps.executeQuery();
        // 判斷賬號密碼是否正確
        if (rs.next()) {
            // 判斷是管理員還是學生
            if (rs.getBoolean(1)) {
                close();
                return 1;
            } else {
                close();
                return 0;
            }
        }
        close();
        return -1;
    }

    // 改密碼
    public static boolean changePwd(String usr, String pwd) {
        String sql = " UPDATE usr SET pwd=? WHERE NAME=?;";
        PreparedStatement ps;
        try {
            ps = getConnection().prepareStatement(sql);
            ps.setString(1, pwd);
            ps.setString(2, usr);
            int n = ps.executeUpdate();
            System.out.println(n);
            if (n > 0) {
                close();
                return true;
            }
        } catch (SQLException e) {
        }
        close();
        return false;
    }

    // 按id查詢書籍
    public static Vector<Book> selectByid(String book_id) throws SQLException {
        // SELECT book_id,book_name,book_info,book_total FROM book WHERE
        // book_id='1111';
        Vector<Book> books = null;
        String sql = "SELECT book_id,book_name,book_info,book_total,book_num FROM book WHERE book_id=?";
        PreparedStatement ps = getConnection().prepareStatement(sql);
        ps.setString(1, book_id);
        ResultSet rs = ps.executeQuery();
        while (rs.next()) {
            if (books == null) {
                books = new Vector<Book>();
            }
            Book book = new Book();
            String id = rs.getString(1);
            String name = rs.getString(2);
            String info = rs.getString(3);
            int total = rs.getInt(4);
            int num = rs.getInt(5);
            book.setBook_id(id);
            book.setBook_name(name);
            book.setBook_info(info);
            book.setBook_total(total);
            book.setBook_num(num);
            books.add(book);
        }
        close();
        return books;
    }

    // 按名字匹配書籍
    public static Vector<Book> selectByName(String book_name) throws SQLException {
        // SELECT book_id,book_name,book_info,book_total FROM book WHERE
        // book_name LIKE '%編程%';
        Vector<Book> books = null;
        String sql = " SELECT book_id,book_name,book_info,book_total,book_num FROM book WHERE book_name LIKE ?";
        PreparedStatement ps = getConnection().prepareStatement(sql);
        ps.setString(1, "%" + book_name + "%");
        ResultSet rs = ps.executeQuery();
        while (rs.next()) {
            if (books == null) {
                books = new Vector<Book>();
            }
            Book book = new Book();
            String id = rs.getString(1);
            String name = rs.getString(2);
            String info = rs.getString(3);
            int total = rs.getInt(4);
            int num = rs.getInt(5);
            book.setBook_id(id);
            book.setBook_name(name);
            book.setBook_info(info);
            book.setBook_total(total);
            book.setBook_num(num);
            books.add(book);
        }
        close();
        return books;
    }

    // 添加書籍
    public static boolean addBook(String bookId, String bookName, String bookInfo, int bookTotal, int bookNum) {
        String sql = "insert book values(?,?,?,?,?);";
        PreparedStatement ps;
        try {
            ps = getConnection().prepareStatement(sql);
            ps.setString(1, bookId);
            ps.setString(2, bookName);
            ps.setString(3, bookInfo);
            ps.setInt(4, bookTotal);
            ps.setInt(5, bookNum);
            int n = ps.executeUpdate();
            System.out.println(n);
            if (n > 0) {
                close();
                return true;
            }
        } catch (SQLException e) {
        }
        close();
        return false;
    }

    // 批量刪除書籍DELETE FROM book WHERE book_id='123';
    public static boolean deleteBooks(String[] array) {
        String sql = "DELETE FROM book WHERE book_id=?;";
        PreparedStatement ps;
        int n = 0;
        try {
            ps = getConnection().prepareStatement(sql);
            for (String string : array) {
                ps.setString(1, string);
                n += ps.executeUpdate();
            }
        } catch (SQLException e) {
        }
        if (n > 0) {
            return true;
        } else {
            return false;
        }
    }

    // 修改書籍UPDATE book SET
    // book_name='java編程',book_info='java編程思想',book_total='20',book_num='20'
    // WHERE book_id='23d3';
    public static boolean updateBook(Book book) {
        if (book == null) {
            return false;
        }
        String sql = "UPDATE book SET book_name=?,book_info=?,book_total=?,book_num=? WHERE book_id=?;";
        PreparedStatement ps;
        int n = 0;
        try {
            ps = getConnection().prepareStatement(sql);
            ps.setString(1, book.getBook_name());
            ps.setString(2, book.getBook_info());
            ps.setInt(3, book.getBook_total());
            ps.setInt(4, book.getBook_num());
            ps.setString(5, book.getBook_id());
            n = ps.executeUpdate();
        } catch (SQLException e) {
        }
        if (n > 0) {
            return true;
        } else {
            return false;
        }
    }

    // 關(guān)閉連接
    public static void close() {
        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                log("數(shù)據(jù)庫連接關(guān)閉失敗\n" + e);
            }
        }
    }

    public static void main(String[] args) throws SQLException {// 測試
        /*
         * String sql = "select * from usr;";
         * try {
         * PreparedStatement ps = getConnection().prepareStatement(sql);
         * ResultSet rs = ps.executeQuery();
         * while (rs.next()) {
         * System.out.println(rs.getString(1));
         * System.out.println(rs.getString(2));
         * }
         * } catch (SQLException e) {
         * 
         * e.printStackTrace();
         * }
         */

        // changePwd("tan", "123");
        // Vector<Book> books = selectByid("1111");
        // System.out.println(books.size());
        // Vector<Book> books1 = selectByName("編程");
        // System.out.println(books1.size());

        // addBook("123456789", "c語音", "c語言詳解", 10, 5);
        String[] str = { "233", "5" };
        System.out.println(deleteBooks(str));
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末愉适,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子癣漆,更是在濱河造成了極大的恐慌维咸,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件惠爽,死亡現(xiàn)場離奇詭異癌蓖,居然都是意外死亡,警方通過查閱死者的電腦和手機婚肆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門租副,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人较性,你說我怎么就攤上這事用僧。” “怎么了赞咙?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵责循,是天一觀的道長。 經(jīng)常有香客問我攀操,道長院仿,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任崔赌,我火速辦了婚禮意蛀,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘健芭。我一直安慰自己县钥,他們只是感情好,可當我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布慈迈。 她就那樣靜靜地躺著若贮,像睡著了一般省有。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上谴麦,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天蠢沿,我揣著相機與錄音,去河邊找鬼匾效。 笑死舷蟀,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的面哼。 我是一名探鬼主播野宜,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼魔策!你這毒婦竟也來了匈子?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤闯袒,失蹤者是張志新(化名)和其女友劉穎虎敦,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體政敢,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡其徙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了堕仔。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片擂橘。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖摩骨,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情朗若,我是刑警寧澤恼五,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站哭懈,受9級特大地震影響灾馒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜遣总,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一睬罗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧旭斥,春花似錦容达、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春算芯,著一層夾襖步出監(jiān)牢的瞬間柒昏,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工熙揍, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留职祷,地道東北人。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓届囚,卻偏偏與公主長得像堪旧,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子奖亚,可洞房花燭夜當晚...
    茶點故事閱讀 44,781評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Spring之IoC IoC注入之DI 1.什么是DI? 依賴注入:Depend...
    袁小勝閱讀 441評論 0 0
  • JDBC基礎(chǔ)知識 一淳梦、采用JDBC訪問數(shù)據(jù)庫的基本步驟: A.載入JDBC驅(qū)動程序 B.定義連接URL ...
    java日記閱讀 3,849評論 0 20
  • 前言: 最近爆袍,有一個小伙伴成功獲得好幾份不錯的offer,和他交談的過程中得知面試官問他關(guān)于Spring的問題比較...
    阿秀老師閱讀 452評論 0 0
  • 字節(jié)跳動數(shù)據(jù)分析面經(jīng) 對于一個app說一個你最關(guān)注的指標? 為什么是這個指標而不是其他的 ?視頻類:活躍用戶(比例...
    微斯人_吾誰與歸閱讀 13,279評論 1 16
  • 一 “媽作郭,你在哪呢陨囊?” “別管我在哪?我很好夹攒。你不要擔心蜘醋。” “你們倆又怎么了坝匠ⅰ压语?因為什么啊又打這么狠?编检!” “恁...
    張麗潔Caroline閱讀 173評論 0 0