欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java連接MySQL數(shù)據(jù)庫命令行程序過程

 更新時間:2021年10月12日 16:09:24   作者:guoyp2126  
SQL編程包括兩種形式,一種是過程化編程,主要通過數(shù)據(jù)庫交互式工具,通過存儲過程、觸發(fā)器、函數(shù)等形式的編程;另一種是嵌入式SQL編程,將SQL語句嵌入到高級開發(fā)語言,完成數(shù)據(jù)的各種操作

SQL編程包括兩種形式,一種是過程化編程,主要通過數(shù)據(jù)庫交互式工具,通過存儲過程、觸發(fā)器、函數(shù)等形式的編程;另一種是嵌入式SQL編程,將SQL語句嵌入到高級開發(fā)語言,完成數(shù)據(jù)的各種操作。

命令行程序由于對外依賴的jar包少易上手,通常作為教學示例程序。我們通過命令行 程序介紹嵌入式SQL開發(fā)過程,示例開發(fā)工具選擇idea。

創(chuàng)建表

通過SQLyol建立表student;

CREATE TABLE student(
Sno VARCHAR(10) PRIMARY KEY,
Sname VARCHAR(50),
Ssex   VARCHAR(2), 
Sage   INT,
Sdept VARCHAR(50)
)

插入數(shù)據(jù):

在這里插入圖片描述

創(chuàng)建命令行程序

新建一個命令行程序,打開idea工具,選擇:File—>New—>Project,彈出對話框,如下圖所示

在這里插入圖片描述

直接點擊Next按鈕,進入到下一個Tab頁,勾選Create project from template,選擇Command line App

在這里插入圖片描述

點擊Next進入下一個Tab頁,如圖所示

在這里插入圖片描述

輸入項目名稱,選擇項目路徑,書寫基本包包名,基本包名一般由com+域名組成,確保其唯一性。填寫完成后,點擊finish按鈕,完成命令行程序的創(chuàng)建,創(chuàng)建完成的頁面如下圖所示

在這里插入圖片描述

下載并導入jar包

下載mysql-connector-java-8.0.13.jar;下載地址,,將jar包存入本地目錄。
項目中導入Jar包。點擊File—>ProjectStructure 打開對話框,如下圖所示

在這里插入圖片描述

點擊右側(cè)“+”,選擇“JARs or directories”,彈出對話框,選擇剛才下載的jar包,如下圖所示:

在這里插入圖片描述

點擊OK,完成jar包的導入,導入后就可以在工程中看到導入的jar包,如下圖

在這里插入圖片描述

創(chuàng)建工具包

在開始練習時,就應該形成一個良好的習慣,將不同類型的類放置在不同包中,創(chuàng)建工具包util,用存放公共使用的工具類,這里的類一般使用靜態(tài)方法。
創(chuàng)建數(shù)據(jù)庫連接類:

在這里插入圖片描述

代碼如下:

public class MySqlConnection {
    private static Connection con=null;
    private static String driveName ="com.mysql.cj.jdbc.Driver";
    private static String url = "jdbc:mysql://127.0.0.1:3306/sl?serverTimezone=GMT%2b8";
    private static String user="root";
    private static String pws="root";
    
    private  MySqlConnection(){}
    public static Connection getCon(){
       if(con==null){
           con = getConnection();
       }
       return con;
    }
    private static Connection getConnection(){
        Connection connection = null;
        try {
            Class.forName(driveName);
            connection = DriverManager.getConnection(url,user,pws);

        } catch (ClassNotFoundException | SQLException e) {
            e.printStackTrace();
        }finally {
            return connection;
        }
    }
}

這里的方法使用static 修飾代表是靜態(tài)方法,該方法屬于類,而不是對象;
創(chuàng)建SQL執(zhí)行包裝類,完成數(shù)據(jù)庫各種方法的執(zhí)行,這里僅寫了一個返回ResultSet方法,代碼如下:

public class MysqlHelp {
    public  static ResultSet query(String sql)  {
        Connection con = MySqlConnection.getCon();
        ResultSet result =null;

        try {
            Statement stmt = con.createStatement();
            result= stmt.executeQuery(sql);

        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            return result;
        }
    }
}

創(chuàng)建實體類

創(chuàng)建pojo包,在該包下創(chuàng)建實體類Student,實體類只包含私有屬性和get、set方法,為了簡單期間,增加了一個lombok包,就不需要寫get、set方法。lombok jar的安裝,F(xiàn)ile—>Settings ,打開對話框如下圖:

在這里插入圖片描述

在實體類上加主解符“@Data”即可。

當然也可以不用Lombok,老老實實的寫get、set方法也可以,使用lombok代碼如下

@Data
public class Student {
    private String sno;
    private String sName;
    private String sSex;
    private int sAge;
    private String sDept;

    public Student(String sno,String name, String sex,int age,String dept){
        this.setSno(sno);
        this.setSAge(age);
        this.setSName(name);
        this.setSDept(dept);
        this.setSSex(sex);
    }

    public String getInfo(){
        return "學號:"+sno +"姓名:"+sName+"性別:"+sSex+"年齡:"+"院系:"+sDept;
    }
}

為了演示方便,在實體類中增加了一個構造函數(shù)和字符串的輸出,實體類當然完全沒有這兩個方法。

創(chuàng)建持久化層

創(chuàng)建一個dao包,包中創(chuàng)建類StudentDao,完成數(shù)據(jù)的存取操作,代碼如下

public class StudentDao {
    public void getStudentInfo(){
        String sql="SELECT Sno AS sno,Sname AS NAME,Ssex AS sex,Sage AS age,Sdept AS dept FROM student";

        ResultSet result = MysqlHelp.query(sql);
        if(result!=null) {
            while (true) {
                try {
                    if (!result.next()) break;
                    String sno = result.getString("sno");
                    String name = result.getString("name");
                    int age = result.getInt("age");
                    String dept = result.getString("dept");
                    String sex = result.getString("sex");
                    Student student = new Student(sno, name, sex, age, dept);
                    System.out.println(student.getInfo());
                } catch (SQLException e) {
                    e.printStackTrace();
                }

            }
        }
    }

這里調(diào)用了上面定義的 MysqlHelp的query方法,完成數(shù)據(jù)的存取及結構化數(shù)據(jù)向面向?qū)ο髮嶓w類的轉(zhuǎn)換。

業(yè)務層調(diào)用

打開main函數(shù),寫入下代碼,完成dao層方法調(diào)用

public class Main {

    public static void main(String[] args) {
        StudentDao student = new StudentDao();
        student.getStudentInfo();
    }
}

執(zhí)行結果如下:

在這里插入圖片描述

總結

在這里盡量使用面向?qū)ο蟮姆庋b技術,將每個類的職責單一化,而不是把所有代碼寫到一起的做法,盡管寫到一起,代碼更好讀,而且簡單。另外思考一個問題,我們能不能把結構化的數(shù)據(jù)自動轉(zhuǎn)換為實體對象,以及數(shù)據(jù)庫的連接、SQL的執(zhí)行交給第三方的程序去做,簡化我們的代碼?答案是肯定的,Mybaits、hibernet就是完成這些工作的框架

以上就是Java連接MySQL數(shù)據(jù)庫創(chuàng)建命令行程序過程的詳細內(nèi)容,更多關于Java連接MySQL數(shù)據(jù)庫的資料請關注腳本之家其它相關文章!

相關文章

  • JPA之QueryDSL-JPA使用指南

    JPA之QueryDSL-JPA使用指南

    Springdata-JPA是對JPA使用的封裝,Querydsl-JPA也是基于各種ORM之上的一個通用查詢框架,使用它的API類庫可以寫出Java代碼的sql,下面就來介紹一下JPA之QueryDSL-JPA使用指南
    2023-11-11
  • 一篇文章弄懂Mybatis中#和$的區(qū)別

    一篇文章弄懂Mybatis中#和$的區(qū)別

    mybatis為我們提供了兩種支持動態(tài)sql的語法#{}以及${},兩者都是動態(tài)的向sql語句中傳入需要的參數(shù),下面這篇文章主要給大家介紹了如何通過一篇文章弄懂Mybatis中#和$區(qū)別的相關資料,需要的朋友可以參考下
    2021-12-12
  • InputStreamReader 和FileReader的區(qū)別及InputStream和Reader的區(qū)別

    InputStreamReader 和FileReader的區(qū)別及InputStream和Reader的區(qū)別

    這篇文章主要介紹了InputStreamReader 和FileReader的區(qū)別及InputStream和Reader的區(qū)別的相關資料,需要的朋友可以參考下
    2015-12-12
  • JavaFX之TableView的使用詳解

    JavaFX之TableView的使用詳解

    這篇文章主要介紹了JavaFX之TableView的使用,有需要的朋友可以參考一下
    2013-12-12
  • SpringBoot3集成Quartz的示例代碼

    SpringBoot3集成Quartz的示例代碼

    Quartz由Java編寫的功能豐富的開源作業(yè)調(diào)度框架,可以集成到幾乎任何Java應用程序中,并且能夠創(chuàng)建多個作業(yè)調(diào)度,在實際的業(yè)務中,有很多場景依賴定時任務,比如常見的:訂單超時處理,業(yè)務識別和預警通知等,本文介紹了SpringBoot3如何集成Quartz
    2023-08-08
  • Java排序算法總結之歸并排序

    Java排序算法總結之歸并排序

    這篇文章主要介紹了Java排序算法總結之歸并排序,較為詳細的分析了歸并排序的原理與java實現(xiàn)技巧,需要的朋友可以參考下
    2015-05-05
  • Mybatis把返回結果封裝成map類型的實現(xiàn)

    Mybatis把返回結果封裝成map類型的實現(xiàn)

    本文主要介紹了Mybatis把返回結果封裝成map類型的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • mybatis查詢SqlServer慢問題及解決

    mybatis查詢SqlServer慢問題及解決

    這篇文章主要介紹了mybatis查詢SqlServer慢問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 詳談java命令的本質(zhì)邏輯揭秘

    詳談java命令的本質(zhì)邏輯揭秘

    一個簡單的java命令背后究竟做了些什么事情,很多朋友提出幾個問題,下面帶領大家一起學習Java命令的本質(zhì)邏輯問題,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • 使用@RequestBody傳遞多個不同對象方式

    使用@RequestBody傳遞多個不同對象方式

    這篇文章主要介紹了使用@RequestBody傳遞多個不同對象方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10

最新評論