집 >데이터 베이스 >MySQL 튜토리얼 >MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약
이 기사에서는 JDBC 프로그래밍 지식 포인트와 관련된 문제를 주로 정리하는 mysql에 대한 관련 지식을 제공합니다. JDBC(Java DataBase Connectivity, Java 데이터베이스 연결)는 SQL 문을 실행하는 데 사용되는 Java API로, 다양한 관계형 데이터베이스를 Java 언어로 작성된 일련의 클래스와 인터페이스로 구성하여 모두에게 도움이 되기를 바랍니다.
추천 학습: mysql 동영상 튜토리얼
이 글에서는 JDBC 프로그래밍을 소개합니다. JDBC(Java DataBase Connectivity, Java 데이터베이스 연결)는 SQL 문을 실행하는 데 사용되는 Java API로, 다양한 용도로 사용할 수 있습니다. 데이터베이스는 통합 액세스를 제공하며 Java 언어로 작성된 클래스 및 인터페이스 세트로 구성됩니다.
MySQL JDBC 드라이버 패키지는 공식 홈페이지에서 다운 받을 수도 있고, Maven 중앙 웨어하우스에서 다운 받을 수도 있어요. 휴대폰의 "앱 스토어" 소프트웨어로 생각할 수 있습니다. 모바일 앱 스토어에는 모바일 소프트웨어가 포함되어 있고 Maven 중앙 웨어하우스에는 많은 API 및 종속성 패키지가 포함되어 있다는 점을 제외하면 앱 스토어의 기능과 유사합니다.
이제 MySQL이 오라클에 인수되었으니 오라클의 "이미지"가 좀 보기 흉하네요. 공식 홈페이지에서 찾아보실 수 있는데, maven 중앙웨어하우스가 더 찾기 쉬운 것 같아서 maven 중앙웨어하우스로 가보겠습니다. jdbc 드라이버 패키지를 다운로드합니다.
웹사이트: maven 중앙 창고
첫 번째 단계는 웹사이트를 클릭하여 maven 중앙 창고에 들어가는 것입니다.
두 번째 단계는 MySQL을 검색하여 아래와 같이 선택하는 것입니다.
세 번째 단계에서는 클릭하여 주요 버전에 해당하는 jdbc 드라이버 패키지를 찾습니다. MySQL이 버전 5인 경우 드라이버 패키지로 버전 5를 선택합니다. 물론 MySQL이 버전 MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약인 경우에는 드라이버 패키지도 버전 MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약을 선택합니다.
My MySQL은 버전 5이므로 가장 큰 버전 5의 드라이버 패키지를 선택합니다.
MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약단계: 아래 이미지를 클릭하고 따라 드라이버 패키지를 다운로드합니다.
다운로드가 완료되면 드라이버 패키지가 준비됩니다.
컴파일러를 사용하여 프로젝트를 만든 후 다음 단계를 따르세요.
첫 번째 단계는 임의의 이름으로 디렉터리를 만드는 것입니다. code>lib 디렉토리 . lib
目录。
第二步,将下载好的驱动包拷贝到该目录。
第三步,设置选项,右键刚才创建并已经将驱动包拷贝的目录,找到As a Lib…
这样我们的驱动包就导进我们的项目中了,然后我们就能来写jdbc代码了。
第一步,创建DataSource
对象,来描述这个数据库在哪里。
DataSource dataSource = new MysqlDataSource();
其中DataSource
为java.sql
里面的一个jdbc接口,MysqlDataSource
是来源与我们所下载驱动包中的一个实现DataSource
接口的类。
第二步,设置数据库的“位置”(URL),登录数据库的账户名和密码。
//设置数据库所在地址 ((MysqlDataSource)dataSource).setURL("jdbc:mysql://MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약.0.0.MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약:MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약06/jdbctest/characterEncoding=utfMySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약&useSSL=false"); //设置登录数据库的账户名 ((MysqlDataSource)dataSource).setUser("root"); //设置登录数据库的密码 ((MysqlDataSource)dataSource).setPassword("MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약56");
jdbc:mysql://MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약.0.0.MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약:MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약06/jdbctest?characterEncoding=utfMySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약&useSSL=false
就是一个URL,也叫唯一资源定位符。jdbc:mysql
表示该url
是用于jdbc mysql的URL,因为数据库有很多,不止jdbc一种,所以需要细分。
具体含义自主对照:URL类型声明://数据库的地址/数据库名?字符集编码&是否加密
。
第三步,和服务器建立连接,创建好数据源DataSource
对象后,调用该对象的getConnection()
方法,获取java.sql.Connection
DataSource
개체를 만드는 것입니다. 🎜Connection connection = dataSource.getConnection();🎜 그 중
DataSource
는 java.sql
의 jdbc 인터페이스이고 MysqlDataSource
는 우리가 제공하는 드라이버 패키지의 소스이자 구현입니다. DataSource인터페이스 클래스를 다운로드했습니다. 🎜🎜두 번째 단계는 데이터베이스의 "위치"(URL), 데이터베이스에 로그인하기 위한 계정 이름 및 비밀번호를 설정하는 것입니다. 🎜//操作数据库 关键在于构造sql语句 //jdbc 构造的sql语句不需要带上; String sql = "insert into student values(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약, MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약9;张三MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약9;)"; //将sql字符串包装成一个语句对象,表示待执行的sql的对象 PreparedStatement statement = connection.prepareStatement(sql); //执行sql //如果待执行的sql语句操作是insert, update, delete,则使用executeUpdate方法执行,返回值为影响数据的行数 //如果待执行的sql语句操作是select,则使用executeQuery方法执行 int ret = statement.executeUpdate();🎜
jdbc:mysql://MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약.0.0.MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약:MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약06/jdbctest?characterEncoding=utfMySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약&useSSL=false
는 고유 리소스 로케이터라고도 하는 URL입니다. 🎜jdbc:mysql
은 url
이 jdbc mysql의 URL이라는 뜻입니다. jdbc뿐만 아니라 데이터베이스도 많기 때문에 세분화해야 합니다. 🎜🎜구체적인 의미를 직접 확인해보세요: URL 유형문://데이터베이스 주소/데이터베이스 이름?문자 집합 인코딩 및 암호화 여부
. 🎜🎜MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약.MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 데이터베이스 연결 🎜🎜세 번째 단계는 서버와의 연결을 설정하는 것입니다. 데이터 소스 DataSource
객체를 생성한 후 getConnection()
메서드를 호출합니다. java.sql.Connection
객체를 얻기 위한 객체로 데이터베이스와의 연결을 설정합니다. 🎜Connection connection = dataSource.getConnection();
第四步,构造sql
语句字符串,并将该语句包装成PreparedStatement
对象,即调用Connection
对象的prepareStatement
方法,参数是sql字符串,会返回一个PreparedStatement
对象,然后我们再调用PreparedStatement
对象中的executeUpdate
方法或executeQuery
方法执行sql
语句。
我们先以插入操作为例。
//操作数据库 关键在于构造sql语句 //jdbc 构造的sql语句不需要带上; String sql = "insert into student values(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약, MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약9;张三MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약9;)"; //将sql字符串包装成一个语句对象,表示待执行的sql的对象 PreparedStatement statement = connection.prepareStatement(sql); //执行sql //如果待执行的sql语句操作是insert, update, delete,则使用executeUpdate方法执行,返回值为影响数据的行数 //如果待执行的sql语句操作是select,则使用executeQuery方法执行 int ret = statement.executeUpdate();
其中,如果待执行的sql语句操作是insert, update, delete,则使用executeUpdate方法执行,返回值为影响数据的行数,如果待执行的sql语句操作是select,则使用executeQuery方法执行,返回值是一个ResultSet
结果表对象。
第五步,释放资源,我们执行完毕sql语句后需要及时地将资源释放,在JDBC编程中,最常见需要释放的类或接口有三个,分别是Connection
,PreparedStatement
,ResultSet
,其中前面两个在jdbc插入操作中已经使用过了,而最后一个,即ResultSet
,它是在执行查询语句需要用到的,调用executeQuery
方法执行查询语句之后,会返回一个“临时表”,该“临时表”上储存了查询的结果,我们可以通过遍历该结果表来获取查询数据库的结果。
//此时sql语句已经执行完毕了,需要释放资源statement.close();connection.close();
使用jdbc编程进行插入操作全部代码:
import com.mysql.jdbc.jdbcMySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약.optional.MysqlDataSource;import javax.sql.DataSource;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.SQLException;import java.util.Scanner;public class TestJdbc { public static void main(String[] args) throws SQLException { DataSource dataSource = new MysqlDataSource(); //设置数据库所在地址 ((MysqlDataSource)dataSource).setURL("jdbc:mysql://MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약.0.0.MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약:MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약06/jdbctest?characterEncoding=utfMySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약&useSSL=false"); //设置登录数据库的账户名 ((MysqlDataSource)dataSource).setUser("root"); //设置登录数据库的密码 ((MysqlDataSource)dataSource).setPassword("MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약56"); //建立连接 Connection connection = dataSource.getConnection(); //操作数据库 关键在于构造sql语句 //jdbc 构造的sql语句不需要带上; String sql = "insert into student values(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약, MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약9;张三MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약9;)"; //将sql字符串包装成一个语句对象,表示待执行的sql的对象 PreparedStatement statement = connection.prepareStatement(sql); //执行sql //如果待执行的sql语句操作是insert, update, delete,则使用executeUpdate方法执行,返回值为影响数据的行数 //如果待执行的sql语句操作是select,则使用executeQuery方法执行 int ret = statement.executeUpdate(); //此时sql语句已经执行完毕了,需要释放资源 statement.close(); connection.close(); }}
运行结果,我们通过查询数据库的表的结果来进行观察:
mysql> create database jdbctest;Query OK, MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 row affected (0.0MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 sec)mysql> use jdbctest;Database changed mysql> create table student(id int, name varchar(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약0));Query OK, 0 rows affected (0.0MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 sec)mysql> show tables;+--------------------+| Tables_in_jdbctest |+--------------------+| student |+--------------------+MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 row in set (0.00 sec)-- 执行jdbc代码后查询mysql> select * from student;+------+--------+| id | name |+------+--------+| MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 | 张三 |+------+--------+MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 row in set (0.00 sec)
程序运行结果,表示MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약行受到了影响。
我们发现我们的sql语句是完完全全写死的,这一点不好,我们可以使用输入的操作让用户输入信息进行插入,那就需要使用到Scanner
类了。
我们得到用户输入的信息后,我们需要对信息进行整合,最容易想到的方式就是字符串拼接,但是这么做有如下的缺点,一是容易写错,特别是单双引号比较多的情况下,二是不安全,黑客可以使用sql注入的方式来修改数据库。
所以更好的方法就是把sql字符串中待输入的信息使用?
来代替或者叫做占位,然后通过PreparedStatement
中的setXXX
系列方法来逐个设置每个?
的内容是什么。
这个系列的方法,第一个参数表示sql待执行对象中第多少个?
,第二个参数表示将这个?
设置的内容。比如:
//操作数据库 关键在于构造sql语句 //jdbc 构造的sql语句不需要带上; String sql = "insert into student values(?, ?)"; //将sql字符串包装成一个语句对象,表示待执行的sql的对象 PreparedStatement statement = connection.prepareStatement(sql); statement.setInt(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약, id); statement.setString(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약, name);
完整代码:jdbc插入操作源代码
运行结果:
数据库查询结果:
mysql> select * from student;+------+--------+| id | name |+------+--------+| MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 | 张三 || MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 | 李四 |+------+--------+MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 rows in set (0.00 sec)
在jdbc编程中,删除操作和更新操作,它的步骤与插入操作是一模一样的,只不过就是构造的sql
语句不一样,其他都一样。
删除操作关键代码:
//用户输入 System.out.println("请输入需要删除的学号:"); int id = sc.nextInt(); //操作数据库 关键在于构造sql语句 //jdbc 构造的sql语句不需要带上; String sql = "delete from student where id = ?"; PreparedStatement statement = connection.prepareStatement(sql); statement.setInt(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약, id); System.out.println("statement" + statement);
jdbc删除操作完整代码:源代码地址
程序运行结果:
数据库查询结果:
mysql> select * from student;+------+--------+| id | name |+------+--------+| MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 | 张三 |+------+--------+MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 row in set (0.00 sec)
更新操作关键代码:
//用户输入 需要修改的id 与修改后的姓名 System.out.println("请输入需要修改的学号:"); int id = sc.nextInt(); sc.nextLine(); System.out.println("请输入修改后的姓名:"); String afterName = sc.nextLine(); //操作数据库 关键在于构造sql语句 //jdbc 构造的sql语句不需要带上; String sql = "update student set name = ? where id = ?"; PreparedStatement statement = connection.prepareStatement(sql); statement.setString(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약, afterName); statement.setInt(MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약, id); System.out.println("statement" + statement);
jdbc更新操作完整代码:源代码地址
程序运行结果:
数据库查询结果:
mysql> select * from student;+------+--------+| id | name |+------+--------+| MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 | 王五 |+------+--------+MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 row in set (0.00 sec)
jdbc的查询操作与插入删除更新操作有一点点不同,执行查询sql语句的时候是调用executeQuery
方法来执行语句的,并且会带回查询的结果,我们可以通过类似与迭代器的操作来获取查询的结果,这个结果集使用完后需要将它释放。
关键代码:
//操作数据库 关键在于构造sql语句 //jdbc 构造的sql语句不需要带上; String sql = "select * from student"; PreparedStatement statement = connection.prepareStatement(sql); //执行sql 查询操作返回的不是int 而是一个临时表 使用ResultSet对象表示这个临时表 ResultSet ret = statement.executeQuery(); //便利结果集合 //预期结果格式// +------+--------+// | id | name |// +------+--------+// | MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약 | 王五 |// +------+--------+ while (ret.next()) { int id = ret.getInt("id"); String name = ret.getString("name"); System.out.println("id:" + id + ", name:" + name); } //关闭资源 ret.close(); statement.close(); connection.close();
jdbc查询操作完代码:源代码地址
程序运行结果:
好了,JDBC的全部内容差不多就是这一些,所有的完整代码链接:地址。
推荐学习:mysql视频教程
위 내용은 MySQL 데이터베이스 JDBC 프로그래밍 지식 포인트 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!