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
    评论
好的,我会尽量回答你的问题。关于Java连接MySQL数据库实现登录注册功能,以下是一个简单的实现步骤: 1.下载并安装MySQL数据库,安装完成后,创建一个名为“test”的数据库。 2.下载并安装JDBC驱动程序,将下载的JDBC驱动程序的jar包添加到项目的classpath中。 3.编写Java代码,实例化JDBC驱动程序,连接MySQL数据库,创建用户表,实现用户的注册和登录功能。 以下是一个简单的Java代码示例: ``` import java.sql.*; public class JdbcTest { public static void main(String[] args) { // 数据库连接信息 String url = "jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC"; String username = "root"; String password = "123456"; // 注册JDBC驱动程序 try { Class.forName("com.mysql.cj.jdbc.Driver"); } catch (ClassNotFoundException e) { System.out.println("找不到JDBC驱动程序!"); e.printStackTrace(); return; } // 连接MySQL数据库 Connection conn = null; try { conn = DriverManager.getConnection(url, username, password); } catch (SQLException e) { System.out.println("连接MySQL数据库失败!"); e.printStackTrace(); return; } // 创建用户表 Statement stmt = null; try { stmt = conn.createStatement(); String sql = "create table if not exists user(id int primary key auto_increment, username varchar(50) not null, password varchar(50) not null)"; stmt.executeUpdate(sql); } catch (SQLException e) { System.out.println("创建用户表失败!"); e.printStackTrace(); return; } finally { if (stmt != null) { try { stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } } // 用户注册 PreparedStatement pstmt = null; try { String sql = "insert into user(username, password) values (?, ?)"; pstmt = conn.prepareStatement(sql); pstmt.setString(1, "user1"); pstmt.setString(2, "123456"); pstmt.executeUpdate(); } catch (SQLException e) { System.out.println("用户注册失败!"); e.printStackTrace(); return; } finally { if (pstmt != null) { try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } } } // 用户登录 ResultSet rs = null; try { String sql = "select * from user where username=? and password=?"; pstmt = conn.prepareStatement(sql); pstmt.setString(1, "user1"); pstmt.setString(2, "123456"); rs = pstmt.executeQuery(); if (rs.next()) { System.out.println("用户登录成功!"); } else { System.out.println("用户名或密码错误!"); } } catch (SQLException e) { System.out.println("用户登录失败!"); e.printStackTrace(); } finally { if (rs != null) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } if (pstmt != null) { try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } } } // 关闭数据库连接 try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们先注册了JDBC驱动程序,然后连接MySQL数据库,接着创建了一个名为“user”的用户表,实现了用户的注册和登录功能。你可以根据自己的需求修改代码中的数据库连接信息和SQL语句

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值