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;
		}
		
		
	}

}

发布了42 篇原创文章 · 获赞 16 · 访问量 3388

猜你喜欢

转载自blog.csdn.net/qq_41542638/article/details/104287115