學(xué)習(xí)筆記 | JAVA調(diào)用MySQL數(shù)據(jù)庫(kù)

最近可能需要用到用java調(diào)用MySQL數(shù)據(jù)庫(kù),java提供了接口,打算趕緊學(xué)來(lái)用用碎节!

軟件使用:Eclipse。

下載

java連接MySQL需要驅(qū)動(dòng)包抵卫,所以需要下載jar包狮荔。網(wǎng)上各處都有提供.

一般長(zhǎng)這樣

mysql-connector-java-5.1.38.jar

配置

1.新建一個(gè)項(xiàng)目胎撇,在自己的項(xiàng)目新建一個(gè)文件夾(用來(lái)存儲(chǔ)jar包)

將自己下載的jar包直接拖入這個(gè)文件夾就行了。

2.接下來(lái)在項(xiàng)目下右鍵選擇Configure Build Path

image

3.選擇Libraries下的Add JARS...找到下載的jar包殖氏,完成晚树!

image

使用

首先import sql包

import java.sql.*;

在自己本身MySQL有一個(gè)數(shù)據(jù)庫(kù)后

image

我們創(chuàng)建一些初始數(shù)據(jù)

/*
MySQL的JDBC URL編寫方式:
jdbc:mysql://主機(jī)名稱:連接端口/數(shù)據(jù)庫(kù)名稱?參數(shù)=值
為了避免中文亂碼要設(shè)置"characterEncoding=utf8"
*/

//創(chuàng)建數(shù)據(jù)庫(kù)URL
static final String DB_URL = "jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=true";

// 數(shù)據(jù)庫(kù)的用戶名與密碼,需要根據(jù)自己的設(shè)置
static final String USER = "root";
static final String PASS = "root";

創(chuàng)建完雅采,在主函數(shù)加載驅(qū)動(dòng)程序及使用

public static void main(String[] args) {
    Connection con = null;
//1. 注冊(cè) JDBC 驅(qū)動(dòng)
    Class.forName("com.mysql.jdbc.Driver");
    System.out.println("成功加載MySQL驅(qū)動(dòng)");
//2. 獲得數(shù)據(jù)庫(kù)連接
    System.out.println("連接數(shù)據(jù)庫(kù)...");
    Connection conn = DriverManager.getConnection(DB_URL,USER,PASS);
    System.out.println("成功連接數(shù)據(jù)庫(kù)");
//3. 成功即可操作數(shù)據(jù)庫(kù)爵憎,創(chuàng)建Statenment實(shí)例
    Statement stmt = conn.createStatement();
    // Statement里面帶有很多方法,比如executeUpdate可以實(shí)現(xiàn)插入婚瓜,更新和刪除等
    ResultSet rs = stmt.executeQuery("SELECT * FROM websites");
//4. 如果有數(shù)據(jù)宝鼓,rs.next()返回true
    while(rs.next()){
        System.out.println(" 名稱:"+rs.getString("name")+" 地址:"+rs.getString("url"));
    }
}

最簡(jiǎn)單就是上面四個(gè)步驟,我分別解釋了上面意思巴刻。

其實(shí)還需要有處理各種錯(cuò)誤的情況愚铡,還有斷開(kāi)連接的函數(shù)。

讓我們看看結(jié)果呈現(xiàn)上面吧

image

可見(jiàn)已經(jīng)成功連接數(shù)據(jù)庫(kù)胡陪,并且用sql語(yǔ)句調(diào)用數(shù)據(jù)庫(kù)沥寥。

創(chuàng)建數(shù)據(jù)表并插入數(shù)據(jù)

 public static void main(String[] args) {
        Connection conn=null;
        Statement  stmt=null;
    try {
        //1.加載驅(qū)動(dòng)程序
        Class.forName("com.mysql.jdbc.Driver");
        
        //2. 獲得數(shù)據(jù)庫(kù)連接
        System.out.println("連接數(shù)據(jù)庫(kù)...");
        conn = DriverManager.getConnection(DB_URL, USER, PASS);
        
        //3.操作數(shù)據(jù)庫(kù),實(shí)現(xiàn)增刪改查
        stmt = conn.createStatement();
        String mysql;
        mysql="create table student(NO char(20),name varchar(20),primary key(NO))";
        //創(chuàng)建表格
        
        int result=stmt.executeUpdate(mysql);
        //在執(zhí)行之后柠座,查看受影響行數(shù)邑雅,返回-1代表不成功
        
        if(result!=-1) {
            System.out.println("創(chuàng)建students表格成功");
            mysql = "insert into student(NO,name) values('2016001','haige')";
            result= stmt.executeUpdate(mysql);
            mysql = "insert into student(NO,name) values('2016002','Mr.chen')";
            result= stmt.executeUpdate(mysql);
            System.out.println("插入完成");
            
            mysql = "select * from student";
            ResultSet rs = stmt.executeQuery(mysql);
            //執(zhí)行查詢語(yǔ)句看結(jié)果
            
            System.out.println("學(xué)號(hào)\t姓名");
            while(rs.next()){
                String student_id=rs.getString(1);
                String student_name =rs.getString(2);
                System.out.println(student_id+"\t"+student_name);
            }
            rs.close();
            stmt.close();
            conn.close();
        }
      }catch (SQLException e) {
          System.out.println("MySQL操作錯(cuò)誤");
          e.printStackTrace();
      } catch (Exception e) {
          e.printStackTrace();
      }
      System.out.println("程序結(jié)束!");
  }

以上我加入了try-catch是為了在錯(cuò)誤時(shí)可以檢測(cè)出錯(cuò)誤的地方妈经,可以不加淮野。

還加入了close關(guān)閉數(shù)據(jù)庫(kù)的連接的操作。

image

更新刪除操作

//SQL語(yǔ)句
update student set name=? where NO='2016002'

現(xiàn)在對(duì)數(shù)據(jù)庫(kù)進(jìn)行更新刪除操作

public static void main(String[] args) {
        Connection conn=null;
        Statement  stmt=null;
    try {
        //1.加載驅(qū)動(dòng)程序
        Class.forName("com.mysql.jdbc.Driver");
        
        //2. 獲得數(shù)據(jù)庫(kù)連接
        System.out.println("連接數(shù)據(jù)庫(kù)...");
        conn = DriverManager.getConnection(DB_URL, USER, PASS);
        
        //3.操作數(shù)據(jù)庫(kù)狂塘,實(shí)現(xiàn)增刪改查
        stmt = conn.createStatement();
        String mysql,mysql2,mysql3;
        
        //更新操作
        mysql="update student set name=? where NO='2016002'";
        PreparedStatement pst=conn.prepareStatement(mysql);
        pst.setString(1, "chenxx");
        pst.executeUpdate();
        System.out.println("更新為chenxx完成");
        
        //刪除操作
        mysql2="delete from student where name=?";
        pst = conn.prepareStatement(mysql2);
        pst.setString(1, "haige");
        pst.executeUpdate();
        System.out.println("刪除haige完成");
        
        //查詢操作
        mysql3="select * from student";
        ResultSet rs = stmt.executeQuery(mysql3);
        System.out.println("查詢完成");
        
        //執(zhí)行查詢語(yǔ)句看結(jié)果
        System.out.println("學(xué)號(hào)\t姓名");
        while(rs.next()){
            String student_id=rs.getString(1);
            String student_name =rs.getString(2);
            System.out.println(student_id+"\t"+student_name);
        }
        rs.close();
        stmt.close();
        conn.close();
            
      }catch (SQLException e) {
          System.out.println("MySQL操作錯(cuò)誤");
          e.printStackTrace();
      }catch (Exception e) {
          e.printStackTrace();
      }
      System.out.println("程序結(jié)束录煤!");
  }
image

很好,結(jié)果如我們所料荞胡!

現(xiàn)在暫時(shí)沒(méi)啥問(wèn)題妈踊,目前還只是基礎(chǔ),等到真正使用起來(lái)可能會(huì)有一些問(wèn)題泪漂,到時(shí)候再記錄下來(lái)吧廊营!

-to be continue-

學(xué)習(xí)筆記

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市萝勤,隨后出現(xiàn)的幾起案子露筒,更是在濱河造成了極大的恐慌,老刑警劉巖敌卓,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件慎式,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)瘪吏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門癣防,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人掌眠,你說(shuō)我怎么就攤上這事蕾盯。” “怎么了蓝丙?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵级遭,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我渺尘,道長(zhǎng)挫鸽,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任沧烈,我火速辦了婚禮掠兄,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘锌雀。我一直安慰自己,他們只是感情好迅诬,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布腋逆。 她就那樣靜靜地躺著,像睡著了一般侈贷。 火紅的嫁衣襯著肌膚如雪惩歉。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,708評(píng)論 1 305
  • 那天俏蛮,我揣著相機(jī)與錄音撑蚌,去河邊找鬼。 笑死搏屑,一個(gè)胖子當(dāng)著我的面吹牛争涌,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播辣恋,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼亮垫,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了伟骨?” 一聲冷哼從身側(cè)響起饮潦,我...
    開(kāi)封第一講書(shū)人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎携狭,沒(méi)想到半個(gè)月后继蜡,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年稀并,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了仅颇。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡稻轨,死狀恐怖灵莲,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情殴俱,我是刑警寧澤政冻,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站线欲,受9級(jí)特大地震影響明场,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜李丰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一苦锨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧趴泌,春花似錦舟舒、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至吉捶,卻和暖如春夺鲜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背呐舔。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工币励, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人珊拼。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓食呻,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親杆麸。 傳聞我的和親對(duì)象是個(gè)殘疾皇子搁进,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355

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