Java如何连接MySQL数据库并执行基本的SQL语句——JDBC基本操作

连接数据库

1、导入jar包mysql-connector-java-5.1.12-bin.jar,版本号可根据MySQL版本选择
Maven依赖
2、注册驱动:Class.forName("com.mysql.cj.jdbc.Driver");
3、设置MySQL连接链接:String url ="jdbc:mysql://192.168.91.4:3306/myDB" \\myDB为一个数据库的库名;
4、;创建和MySQL的连接通道:Connection conn=DriverManager.getConnection(url, "root", "123456"); \\root 为用户名 ,123456为密码

操作数据库

1、定义一个执行者来执行SQL语句:Statement stat= conn.createStatement();
2、执行对应的SQL语句

	String sql1=
				"create table if not exists user(account varchar(20) PRIMARY key,password varchar(20))";
		String sql2 ="insert into user values('ZepngLin','12345')";			
		stat.execute(sql1);
		stat.execute(sql2);
		

查询数据库

使用ResultSet类接收查询结果,该类相当于一个二维数组

		String sql4 ="select * from user";
		ResultSet re= stat.executeQuery(sql4);

遍历结果集:

			while(re.next()) {
				System.out.println(re.getString(1)+" "+re.getString(2));  //按序号查找,序号从1开始,也可以按字段名查找
			}
			

结束后关闭各个对象节约资源

			conn.close();
			stat.close();
			re.close();

附代码(内容杂乱,仅仅为测试代码)

package myTestProject;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import com.mysql.cj.jdbc.Driver;
import com.mysql.cj.protocol.Resultset;
public class DB {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String url ="jdbc:mysql://192.168.91.4:3306/myDB";
		String sql1=
				"create table if not exists user(account varchar(20) PRIMARY key,password varchar(20))";
		String sql2 ="insert into user values('ZepngLin','12345')";
		String sql3 ="insert into user values('Wefngdai','54321')";
		String sql4 ="select * from user";
		try {
			Class.forName("com.mysql.cj.jdbc.Driver");
			System.out.println("注册驱动成功");
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			System.out.println("注册驱动失败");
			e.printStackTrace();
			return ;
		}
		Connection conn=null;
		try {
			conn=DriverManager.getConnection(url, "root", "ZepngLin_42");
			Statement  stat= conn.createStatement();
			stat.execute(sql1);
			stat.execute(sql2);
			stat.execute(sql3);
			ResultSet re= stat.executeQuery(sql4);
			while(re.next()) {
				System.out.println(re.getString(1)+" "+re.getString(2));
			}
			conn.close();
			stat.close();
			re.close();
			System.out.println("连接数据库成功");
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			System.out.println("连接数据库失败");
			e.printStackTrace();
			return;
		}
		
		
	}

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值