IDEA导入MySQL的jdbc驱动,并操作数据库

将MySQL的jdbc驱动,导入IDEA的方式,虽然也能连接并且操作数据库,但并不推荐这种方式,推荐使用Maven工程的方式:https://www.cnblogs.com/dadian/p/11938707.html

 

1、JDBC下载链接

 

2、选择下载内容,并进行下载

    • 操作系统选择Platform Independent,下方列表中的两条记录,后缀tar.gz的是Linux版本,.zip的是windows版本。
    
 
    • 这里下载windows版本的jdbc驱动,版本为8.0.18
    
 
    • 跳过登录,直接点击红框里的内容,进行下载
  
 

3、将驱动导入java项目

    • 在IDEA里面创建一个java项目
    
 
    • 选择创建Java项目,JDK这里选择1.8,直接Next
    
 
    • 勾选按模板创建,Next
    
 
    • 输入项目名称和项目地址,Finish
    
 
    • 项目创建完成的界面如下
    
 
    • 在项目中建一个名为lib(名称建议就用lib)的文件夹
    
 
    • 对之前下载来的zip文件进行解压(mysql-connector-java-8.0.18.jar ),并进入解压出来的文件夹
    
    
 
    • 复制其中的mysql-connector-java-8.0.18.jar文件,在lib文件夹上右键,粘贴到IDEA中,刚刚新建的lib文件夹里
    
    
    
 

4、让导入的驱动生效

    • 在IDEA中点击 File——Project Structure
    
 
    • 其中的 Module 模块,Dependencies 选项卡
    
 
    • 点击最右边的加号(+),选择 JARS or directories
    
 
    • 在弹出的窗口中选择刚刚导入 lib 文件夹的驱动,点击Ok
    
 
    • 可以看到Module模块中,多出了一个mysql驱动,最后点击Apply,然后Ok
    
 

5、注册数据库驱动,并向数据库内插入数据

  • 在src下新建一个LinkDatabseInsert类
 1 import java.sql.Connection;
 2 import java.sql.DriverManager;
 3 import java.sql.PreparedStatement;
 4 import java.sql.SQLException;
 5 
 6 public class LinkDatabseInsert{
 7     public static void main(String[] args) throws ClassNotFoundException, SQLException {
 8         //1.注册数据库的驱动
 9         Class.forName("com.mysql.jdbc.Driver");
10         //2.获取数据库连接(里面内容依次是:"jdbc:mysql://主机名:端口号/数据库名","用户名","登录密码")
11         Connection connection = DriverManager.getConnection("jdbc:mysql://rm-uf6lgk4fdxego.mysql.rds.aliyuncs.com:3306/study","root","wY123!");
12         //3.需要执行的sql语句(?是占位符,代表一个参数)
13         String sql = "insert into stu(id,name,age) values(?,?,?)";
14         //4.获取预处理对象,并依次给参数赋值
15         PreparedStatement statement = connection.prepareCall(sql);
16         statement.setInt(1,11); //数据库字段类型是int,就是setInt;1代表第一个参数
17         statement.setString(2,"小明");    //数据库字段类型是String,就是setString;2代表第二个参数
18         statement.setInt(3,16); //数据库字段类型是int,就是setInt;3代表第三个参数
19         //5.执行sql语句(执行了几条记录,就返回几)
20         int i = statement.executeUpdate();
21         System.out.println(i);
22         //6.关闭jdbc连接
23         statement.close();
24         connection.close();
25     }
26 }

 

  • 运行程序,返回1,说明成功向mysql数据库内插入一条数据
    
 

6、注册数据库驱动,并更新数据库内记录

  • 在src下新建一个LinkDatabseUpdate类
 1 import java.sql.Connection;
 2 import java.sql.DriverManager;
 3 import java.sql.PreparedStatement;
 4 import java.sql.SQLException;
 5 
 6 public class LinkDatabaseUpdate {
 7     public static void main(String[] args) throws ClassNotFoundException, SQLException {
 8         //1.注册数据库的驱动
 9         Class.forName("com.mysql.jdbc.Driver");
10         //2.获取数据库连接(里面内容依次是:"jdbc:mysql://主机名:端口号/数据库名","用户名","登录密码")
11         Connection connection = DriverManager.getConnection("jdbc:mysql://rm-uf6lgk4fdxego.mysql.rds.aliyuncs.com:3306/study","root","wY123!");
12         //3.需要执行的sql语句(?是占位符,代表一个参数)
13         String sql = "update stu set name=?,age=? where id=?";
14         //4.获取预处理对象,并依次给参数赋值
15         PreparedStatement statement = connection.prepareCall(sql);
16         statement.setString(1,"小黄"); //数据库字段类型是String,就是setString;1代表第一个参数
17         statement.setInt(2,28); //数据库字段类型是int,就是setInt;2代表第二个参数
18         statement.setInt(3,10); //数据库字段类型是int,就是setInt;3代表第三个参数
19         //5.执行sql语句(执行了几条记录,就返回几)
20         int i = statement.executeUpdate();
21         System.out.println(i);
22         //6.关闭jdbc连接
23         statement.close();
24         connection.close();
25     }
26 }

 

  • 运行程序,返回1,说明更新id为10的记录成功
    
 

7、注册数据库驱动,并删除数据库内记录

  • 在src下新建一个LinkDatabseDelete类
 1 import java.sql.Connection;
 2 import java.sql.DriverManager;
 3 import java.sql.PreparedStatement;
 4 import java.sql.SQLException;
 5 
 6 public class LinkDatabaseDelete {
 7     public static void main(String[] args) throws ClassNotFoundException, SQLException {
 8         //1.注册数据库的驱动
 9         Class.forName("com.mysql.jdbc.Driver");
10         //2.获取数据库连接(里面内容依次是:"jdbc:mysql://主机名:端口号/数据库名","用户名","登录密码")
11         Connection connection = DriverManager.getConnection("jdbc:mysql://rm-uf6lgk4fdxego.mysql.rds.aliyuncs.com:3306/study","root","wY123!");
12         //3.需要执行的sql语句(?是占位符,代表一个参数)
13         String sql = "delete from stu where id=?";
14         //4.获取预处理对象,并依次给参数赋值
15         PreparedStatement statement = connection.prepareCall(sql);
16         statement.setInt(1,9); //字段类型是int,就是setInt;1代表第一个参数
17         //5.执行sql语句(执行了几条记录,就返回几)
18         int i = statement.executeUpdate();
19         System.out.println(i);
20         //6.关闭jdbc连接
21         statement.close();
22         connection.close();
23     }
24 }

 

  • 运行程序,返回1,说明删除id为9的记录成功
    
 

8、注册数据库驱动,并查询数据库内记录

  • 在src下新建一个LinkDatabseSelect类
 1 import java.sql.*;
 2 
 3 public class LinkDatabseSelect {
 4     public static void main(String[] args) throws ClassNotFoundException, SQLException {
 5         //1.注册数据库的驱动
 6         Class.forName("com.mysql.jdbc.Driver");
 7         //2.获取数据库连接(里面内容依次是:"jdbc:mysql://主机名:端口号/数据库名","用户名","登录密码")
 8         Connection connection = DriverManager.getConnection("jdbc:mysql://rm-uf6lgk4fdxego.mysql.rds.aliyuncs.com:3306/study","root","wY123!");
 9         //3.需要执行的sql语句(?是占位符,代表一个参数)
10         String sql = "select * from stu where id in(?,?)";
11         //4.获取预处理对象,并给参数赋值
12         PreparedStatement statement = connection.prepareStatement(sql);
13         statement.setInt(1,1);  //字段类型是int,就是setInt;1代表第一个参数
14         statement.setInt(2,4);  //字段类型是int,就是setInt;2代表第一个参数
15         //5.执行sql语句(返回结果集)
16         ResultSet resultSet = statement.executeQuery();
17         while(resultSet.next()){    //如果有下一条记录
18             String id = resultSet.getString("id");  //根据列名返回值
19             String name = resultSet.getString("name");  //根据列名返回值
20             int age = resultSet.getInt(3);  //根据列的顺序返回值
21             String gender = resultSet.getString(4);  //根据列的顺序返回值
22             System.out.println(id+"\t"+name+"\t"+age+"\t"+gender);
23         }
24         //6.关闭jdbc连接
25         resultSet.close();
26         statement.close();
27         connection.close();
28     }
29 }

 

  • 运行程序,返回了两条记录,说明查询记录成功
    
 
posted @ 2019-11-26 15:49  打点  阅读(46748)  评论(0编辑  收藏  举报