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

Java訪問數(shù)據(jù)庫實(shí)例詳解

 更新時間:2022年03月01日 11:39:33   作者:小朱同學(xué)的筆記本  
這篇文章主要為大家詳細(xì)介紹了Java訪問數(shù)據(jù)庫實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

JAVA程序想要訪問數(shù)據(jù)庫,需要進(jìn)行如下準(zhǔn)備:

1.安裝一個數(shù)據(jù)庫(這里使用mysql免安裝版)
2.下載該數(shù)據(jù)庫的驅(qū)動包(這里使用mysql官方提供的mysql-connector-java-5.1.39-bin)

PS:我的這個免安裝的MySQL不知道為什么存儲的中文都是亂碼,參考了別人的解決方案修改了my-default.ini文件也不行,如果各位看到這篇文章的大佬有解決辦法,還請不吝賜教,感謝!

一、啟動數(shù)據(jù)庫

將mysql免安裝壓縮包解壓到某目錄下
雙擊 mysql-5.6.24-win32 => bin => mysqld.exe 啟動數(shù)據(jù)庫
正常情況下會閃過一個黑框
打開DOS窗口,進(jìn)入mysql文件夾所在盤(我的是D盤)
依次輸入如下命令:
cd mysql* => cd bin =>mysql -uroot
(出現(xiàn)如下圖提示說明已經(jīng)進(jìn)入數(shù)據(jù)庫,可以開始使用數(shù)據(jù)庫了)

二、創(chuàng)建數(shù)據(jù)庫

你可以直接在DOS窗口輸入sql語句創(chuàng)建數(shù)據(jù)庫;
也可以將你的所有操作保存到一個sql文件,再在DOS窗口導(dǎo)入這個文件。(由于創(chuàng)建數(shù)據(jù)庫的命令較多,這里采用第二種方法)
創(chuàng)建db.sql文件(我保存到了D盤)

create database if not exists stu;
use stu;
drop table if exists classes;
create table classes(
id int(10) primary key auto_increment,
num varchar(12) not null ,
name varchar(45) not null,
teacher varchar(15) not null,
unique(name),
unique(num)
);
insert into classes(num,name,teacher ) values('20170101','Mike','Tom');
insert into classes(num,name,teacher ) values('20170102','Nancy','Tom');
insert into classes(num,name,teacher ) values('20170103','Frank','Tom');

然后在DOS窗口輸入:source d:/db.sql;
(出現(xiàn)如下圖提示說明導(dǎo)入成功)

查看數(shù)據(jù)庫里的數(shù)據(jù)

三、JAVA程序?qū)雑ar包

eclipse里創(chuàng)建項(xiàng)目jdbc
將下載好的jar包復(fù)制到該項(xiàng)目下

右擊jar包 => Build Path => Add To Build Path

四、連接數(shù)據(jù)庫

創(chuàng)建DBCon文件,獲取數(shù)據(jù)庫連接對象

package db;

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

public class DBCon {
?? ?public Connection con=null; ? ?//創(chuàng)建數(shù)據(jù)庫連接對象
?? ?String url="jdbc:mysql://localhost:3306/stu"; ? //指定所要連接的數(shù)據(jù)庫的URL
?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ??? ? ? ?//3306表示要連接的是本地數(shù)據(jù)庫;stu為要連接的具體數(shù)據(jù)庫名稱
?? ?String user="root"; ? ? ? //用戶名
? ? String password=""; ? ? ? //密碼
? ? public Connection getConnection() {
? ? ?? ?try {
?? ??? ??? ?Class.forName("com.mysql.jdbc.Driver"); ? ?//加載數(shù)據(jù)庫驅(qū)動器
?? ??? ??? ?
?? ??? ?} catch (ClassNotFoundException e) {
?? ??? ??? ?// TODO Auto-generated catch block
?? ??? ??? ?e.printStackTrace();
?? ??? ?}
? ? ?? ?try {
?? ??? ??? ?con=(Connection)DriverManager.getConnection(url, user, password);
?? ??? ?} catch (SQLException e) {
?? ??? ??? ?// TODO Auto-generated catch block
?? ??? ??? ?e.printStackTrace();
?? ??? ?}
?? ??? ?return con;
? ? }
}

五、測試

創(chuàng)建Classes類文件,保存和訪問學(xué)生數(shù)據(jù)

public class Classes {
?? ?private String num;
?? ?private String name;
?? ?private String teacher;
?? ?public Classes() {
?? ??? ?super();
?? ??? ?// TODO Auto-generated constructor stub
?? ?}
?? ?public Classes(String num, String name, String teacher) {
?? ??? ?super();
?? ??? ?this.num = num;
?? ??? ?this.name = name;
?? ??? ?this.teacher = teacher;
?? ?}
?? ?public String getNum() {
?? ??? ?return num;
?? ?}
?? ?public void setNum(String num) {
?? ??? ?this.num = num;
?? ?}
?? ?public String getName() {
?? ??? ?return name;
?? ?}
?? ?public void setName(String name) {
?? ??? ?this.name = name;
?? ?}
?? ?public String getTeacher() {
?? ??? ?return teacher;
?? ?}
?? ?public void setTeacher(String teacher) {
?? ??? ?this.teacher = teacher;
?? ?}
?? ?

}

創(chuàng)建測試類Test

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

import db.DBCon;

public class Test {
?? ?
?? ?public static void main(String[] args) {
?? ??? ?// TODO Auto-generated method stub
?? ??? ?Connection cn;
?? ??? ?PreparedStatement psm=null;?? ?//PrepareStatement接口用來執(zhí)行動態(tài)的sql語句
?? ??? ?ResultSet rs;?? ?//ResultSet接口用來暫存數(shù)據(jù)庫查詢出的結(jié)果集
?? ??? ?DBCon dbcon=new DBCon();
?? ??? ?cn=dbcon.getConnection();?? ?//獲取數(shù)據(jù)庫對象
?? ??? ?Classes classes=new Classes();
?? ??? ?String sql="select * from classes";
?? ??? ?try {
?? ??? ??? ?psm=cn.prepareStatement(sql);?? ?//實(shí)例執(zhí)行sql語句
?? ??? ??? ?rs=psm.executeQuery();?? ?//將結(jié)果賦給rs指針
?? ??? ??? ?if(rs.next()) {?? ??? ??? ?//判斷是否查詢到結(jié)果
?? ??? ??? ??? ?rs.absolute(0);?? ??? ?//將rs指針置于結(jié)果集最上方
?? ??? ??? ??? ?while(rs.next()) {
?? ??? ??? ??? ??? ?String classNum=rs.getString(2);
?? ??? ??? ??? ??? ?String className=rs.getString(3);
?? ??? ??? ??? ??? ?String classTeacher=rs.getString(4);
?? ??? ??? ??? ??? ?classes.setNum(classNum);
?? ??? ??? ??? ??? ?classes.setName(className);
?? ??? ??? ??? ??? ?classes.setTeacher(classTeacher);
?? ??? ??? ??? ??? ?System.out.println(classes.getNum()+","+classes.getName()+","+classes.getTeacher());
?? ??? ??? ??? ?}
?? ??? ??? ??? ?
?? ??? ??? ?}
?? ??? ?} catch (SQLException e) {
?? ??? ??? ?// TODO Auto-generated catch block
?? ??? ??? ?e.printStackTrace();
?? ??? ?}
?? ??? ?
?? ?}

}

運(yùn)行Test文件,出現(xiàn)所查詢內(nèi)容

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入解析Java編程中接口的運(yùn)用

    深入解析Java編程中接口的運(yùn)用

    這篇文章主要介紹了Java編程中接口的運(yùn)用,接口是Java面向?qū)ο蟮睦^承特性的體現(xiàn),需要的朋友可以參考下
    2015-10-10
  • SpringBoot Application的exclude不生效問題及排查

    SpringBoot Application的exclude不生效問題及排查

    這篇文章主要介紹了SpringBoot Application的exclude不生效問題及排查,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 深入了解java中的逃逸分析

    深入了解java中的逃逸分析

    這篇文章主要介紹了深入了解java中的逃逸分析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • Java使用split截取字符串過程解析

    Java使用split截取字符串過程解析

    這篇文章主要介紹了Java使用split截取字符串過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-02-02
  • MyBatis-Plus中如何實(shí)現(xiàn)動態(tài)表名

    MyBatis-Plus中如何實(shí)現(xiàn)動態(tài)表名

    這篇文章主要介紹了MyBatis-Plus中如何實(shí)現(xiàn)動態(tài)表名問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • springboot調(diào)用HTML文件注意事項(xiàng)及說明

    springboot調(diào)用HTML文件注意事項(xiàng)及說明

    這篇文章主要介紹了springboot調(diào)用HTML文件注意事項(xiàng)及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • SpringCloudGateway網(wǎng)關(guān)處攔截并修改請求的操作方法

    SpringCloudGateway網(wǎng)關(guān)處攔截并修改請求的操作方法

    這篇文章主要介紹了SpringCloudGateway網(wǎng)關(guān)處攔截并修改請求的操作方法,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-12-12
  • 簡單說說Java SE、Java EE、Java ME三者之間的區(qū)別

    簡單說說Java SE、Java EE、Java ME三者之間的區(qū)別

    本篇文章小編就為大家簡單說說Java SE、Java EE、Java ME三者之間的區(qū)別。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-10-10
  • java編程隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼示例

    java編程隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼示例

    這篇文章主要介紹了java編程隊(duì)列數(shù)據(jù)結(jié)構(gòu)代碼示例,簡單介紹了隊(duì)列的相關(guān)基礎(chǔ)知識,然后通過實(shí)例向大家展示其實(shí)現(xiàn)方法,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • ThreadLocal原理介紹及應(yīng)用場景

    ThreadLocal原理介紹及應(yīng)用場景

    本文詳細(xì)講解了ThreadLocal原理介紹及應(yīng)用場景,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-12-12

最新評論