亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java泛型與數據庫應用實例詳解

發布時間:2020-09-26 11:12:22 來源:腳本之家 閱讀:165 作者:cakincqm 欄目:編程語言

本文實例講述了Java泛型與數據庫應用。分享給大家供大家參考,具體如下:

一 點睛

BaseDao定義了基本的數據庫增刪查改, 之后可以繼承該泛型類,實現各自的增刪查改,或者使用超類的增刪查改,同時每個繼承類還能增加自己的操作。

二 實戰

1 BaseDao.java

import java.lang.reflect.Field;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
public class BaseDao<T> {
  Connection connection;
  PreparedStatement pStatement;
  String urlString = "jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=UTF8";
  String drivString = "com.mysql.jdbc.Driver";
  void OpenDB() {
    try {
      if (connection == null) {
        Class.forName(drivString);
        this.connection = DriverManager.getConnection(urlString, "root", "123456");
      }
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
  void CloseDB() {
    try {
      if (pStatement != null) pStatement.close();
      if (connection != null) connection.close();
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
  public void Save( T t ) {
    OpenDB();
    String table = "";
    String sqlString = "insert into ";
    try {
      table = t.getClass().getSimpleName();
      Field[] fields = t.getClass().getDeclaredFields();
      sqlString += table;
      String sqlNameString = "";
      String sqlValString = "";
      for (Field field : fields) {
        sqlNameString += field.getName() + ",";
        sqlValString += "?,";
      }
      sqlNameString = sqlNameString.substring(0, sqlNameString.length() - 1);
      sqlValString = sqlValString.substring(0, sqlValString.length() - 1);
      pStatement = connection.prepareStatement(sqlString + " (" + sqlNameString + ") values (" + sqlValString + ")");
      int n = 1;
      for (Field field : fields) {
        field.setAccessible(true);
        System.out.println(field.get(t).toString());
        pStatement.setString(n, field.get(t).toString());
        n++;
      }
      pStatement.executeUpdate();
      CloseDB();
    } catch (Exception e) {
      e.printStackTrace();
      CloseDB();
    }
  }
  public void Del( T t ) {
  }
  public void Update( T t ) {
  }
  public void Search( T t ) {
  }
}

2 StudentDao.java

public class StudentDao extends BaseDao<Student> {
}

3 TeacherDao.java

public class TeacherDao extends BaseDao<Teacher> {
}

4 Student.java

public class Student {
  public String name;
  public int age;
  public String dept;
  /**
  * @return the name
  */
  public String getName() {
   return name;
  }
  /**
  * @param name the name to set
  */
  public void setName(String name) {
   this.name = name;
  }
  /**
  * @return the age
  */
  public int getAge() {
   return age;
  }
  /**
  * @param age the age to set
  */
  public void setAge(int age) {
   this.age = age;
  }
  /**
  * @return the dept
  */
  public String getDept() {
   return dept;
  }
  /**
  * @param dept the dept to set
  */
  public void setDept(String dept) {
   this.dept = dept;
  }
}

5 Teacher.java

public class Teacher {
}

6 TestDao.java

public class TestDao {
  public static void main(String[] args) {
   System.out.println("ok");
   Student stud=new Student();
   stud.age=20;
   stud.name="zhangsan";
   stud.dept="computer";
   StudentDao sd=new StudentDao();
   sd.Save(stud);
   System.out.println(stud.dept);
  }
}

三 運行

ok
zhangsan
20
computer
computer

Java泛型與數據庫應用實例詳解

四 怎樣在IDEA中導入jar包

可參考附錄:IDEA連接數據庫(導入jar包)

五 另外一種寫法

StudentDao.java

public class StudentDao<M> extends BaseDao<M> {    // 這里的M可以是任意合法標識符
}

TestDao.java

public class TestDao {
 public static void main(String[] args) {
 System.out.println("ok");
 Student stud=new Student();
 stud.age=20;
 stud.name="zhangsan2";
 stud.dept="computer";
 StudentDao<Student> sd=new StudentDao<>();  // 這里要說明是Student
 sd.Save(stud);
 System.out.println(stud.dept);
 TeacherDao<Teacher> te= new TeacherDao<>();
 }
}

附:IDEA連接數據庫(導入jar包)

Java連接 MySQL 需要驅動包,最新版下載地址為:http://dev.mysql.com/downloads/connector/j/,解壓后得到jar庫文件,然后在對應的項目中導入該庫文件。

IDEA導入jar過程:新建文件夾(名稱任意,這里使用Lib),導入mysql-connector-java-*.*.**-bin.jar如下圖

Java泛型與數據庫應用實例詳解

右鍵點擊jar文件,然后點擊Add as Library,jar導入成功。后面百度java使用mysql即有詳細的訪問mysql的代碼。

Java泛型與數據庫應用實例詳解

ecplice導入jar過程:新建文件夾(名稱任意,這里使用Lib),導入mysql-connector-java-*.*.**-bin.jar如下圖

Java泛型與數據庫應用實例詳解

右鍵-》buildpath-》add to build path

更多java相關內容感興趣的讀者可查看本站專題:《Java面向對象程序設計入門與進階教程》、《Java數據結構與算法教程》、《Java操作DOM節點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》

希望本文所述對大家java程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

崇礼县| 澄城县| 兴仁县| 皋兰县| 天门市| 新密市| 乐东| 神农架林区| 曲周县| 西盟| 项城市| 丰宁| 永康市| 大竹县| 论坛| 霍州市| 新乡市| 黄冈市| 平果县| 弥渡县| SHOW| 永年县| 西城区| 化隆| 庆元县| 莱芜市| 焦作市| 锡林郭勒盟| 牡丹江市| 宁海县| 图木舒克市| 偏关县| 江华| 衡东县| 务川| 高安市| 湾仔区| 台前县| 黔西县| 泰顺县| 桂阳县|