java访问mysql_MySQL入门很简单: 15 java访问MySQL数据库

本文介绍了如何使用Java通过JDBC连接MySQL数据库,包括下载安装JDBC驱动、配置MyEclipse、建立数据库连接,以及使用Statement接口执行SQL语句进行查询、插入、更新和关闭连接。还提供了一个DB.java类的示例,演示了完整操作流程,并讲解了如何备份和还原数据库。
摘要由CSDN通过智能技术生成

1. 连接数据库

1.1 下载安装驱动

java通过JDBC(Java Database Connectivity,Java数据库连接)来访问MySQL数据库。JDBC的编程接口提供的接口和类与MySQL数据库建立连接,然后将SQL语句的执行结果进行处理。

1)下载MySQL Connector/J驱动

http://dev.mysql.com/downloads/file/?id=460363

2)MyEclipse导入JDBC驱动

Window|Perference  Path|User Libraries  New 新建库文件:MySQL-JDBC   Add JARs

右击工程名 Build Path, Add Library, User Library , Next, 选择MySQL-JDBC

1.2 连接MySQL数据库

java.sql 包中存在 DriverManager类, Connection接口,Statement接口,ResultSet接口

DriverManager类:管理驱动程序和连接数据库

Connection接口:管理建立好的数据库连接

Statement接口:执行SQL语句

ResultSet接口: 存储数据库返回的记录

1)使用java.lang.Class类中的forName()指定JDBC驱动的类型

f5b208358a303088e34b2a6a3b983ba0.png

2)使用DriverManager类和Connection接口连接数据库

ab6a42cb2092d14ed237f50a4f155241.png

1880d84648de1a9bcc198655dbdf9b4a.png

2. 操纵数据库

1)创建Statement对象

db9992706f41dd847618db22acd07724.png

2)使用SELECT语句查询数据

28d8f8697c1bc1a782efefa9faa4d6cd.png

bbfe28e3bef18613ab12d9f82ef1fb60.png

3)插入更新或删除数据

ce0e0bd940466f13328e21ffd49c8780.png

4)执行任意SQL语句

80874329189c2036d116f2b0b344c55b.png

1c184dad73da75532007876953ad215a.png

5)关闭创建的对象

0001616f8b73a02da99f93e804fec064.png

3.备份和还原数据库

1)备份

e47225cb4b5747eab615d37e40b22007.png

0b2f601f42bf0e16a8bc0f467823ec17.png

2)还原

79f146a3fb5487c05267cd87f9d04254.png

实例:

1. 编写DB.java类

1)通过DB.java类连接MySQL数据库,然后操作test数据库下的sorce表

2)在DB.java类中查询sorce表中的所有记录,SELECT语句如下: SELECT * FROM sorce

3)向sorce表中插入一条新记录,INSERT语句如下: INSERT INTO sorce VALUES(25,905, 'English', 95);

4)更新id为25的记录,将grade字段的值设为80,UPDATE语句为:UPDATE score SET grade=80 WHERE id=25;

5)关闭打开的所有数据库对象

2. 编写DB_backup_load.java类

1)该类中定义backup()方法,通过backup()方法备份test数据库

2)该类中定义load()方法,通过load()方法还原test数据库

import.java.sql.Connection;

import.java.sql.DriverManager;

import.java.sql.ResultSet;

import.java.sql.SQLException;

import.java.sql.Statement;//执行SELECT INSERTUPDATE语句publicclass DB{public static void main (String args[]){//将JDBC的协议 主机名 端口号 需要连接的数据库等信息复制给字符串变量url

String url="jdbc:mysql://localhost:3306/test";

Stringuser="root";

String passwd="huang";

String sql1="SELECT * FROMscore";

String sql2="INSERT INTO score VALUES(25,905,'English',95)";

String sql3="UPDATE score SET grade=80 WHERE id=25";

try{

Class.forname("com.mysql.jdbc.Driver");//指定MySQL驱动

Connection con=DriverManager.getConnection(url,user,passwd);

System.out.println("连接数据库服务器成功");

Statement stat=con.createStatement();

ResultSet rs=stat.executeQuery(sql1); //执行SELECT//SELECT语句的查询结果存储在rs中,按顺序读取rs中的每一条记录while(rs.next()){int id=rs.getInt("id");int stu_id=rs.getInt("stu_id");

String couse=rs.getString("c.name");int grade=rs.getInt("grade");

System.out.println(id+" "+stu_id+" "+couse+" "+grade);

}//通过executeUpdate()方法执行INSERT语句,执行完成后返回插入的记录int i=stat.executeUpdate(sql2);if(i!=0)

{

System.out.println("INSERT语句执行成功");

}//通过executeUpdate()执行UPDATE语句 完成后返回更新的记录数int j=stat.executeUpdate(sql3);if(j!=0){

System.out.println("UPDATE语句执行成功");

}//如果ResultSet对象不为空,那么调用close()关闭ResultSet对象if(rs!=null){

rs.close();

rs.null;

}//如果Statement对象不为空,那么调用close()关闭Statement对象if(stat!=null){

stat.close();

stat.null;

}//如果Connection对象不为空,那么调用close()关闭Connection对象if(con!=null){

con.close();

con.null;

}

}catch(ClassNotFoundException e){

System.out.print("没有找到MySQL驱动")

}catch(SQLException e){

System.out.print("连接数据库服务器失败")

}

}

}

import java.io.IOException;publicclass DB_backup_load{

private static Stringstr=null;public static void backup(){str="mysqldump -u root -phuang --opt test >c:/test.sql";

try{//使用exec()函数执行mysqldump命令//该代码在windows下运行,需要加上"cmd \c"

Runtime rt=Runtime.getRuntime();

rt.exec("cmd/c"+str);

System.out.println("备份成功");

}catch(IOException e){

e.printStackTrace();

System.out.println("备份失败");

}

}public static void load(){str="mysql -u root -phuang test

try{

RunTime rt=RunTime.getRuntime();

rt.exec("cmd/c"+str);

System.out.println("还原成功");

}catch(IOException e){

e.printStackTrace();

System.out.println("还原失败");

}

}

publ static void main(String args[]){

DB_backup_load db=new DB_backup_load();

db.backup();

db.load();

}

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值