JDBC操作步骤以及MySQL数据库连接操作
jdbc连接数据库的四个步骤
jdbc连接数据库的四个步骤一、引入jdbc相关的jar包在使用jdbc连接数据库之前,需要先引入jdbc相关的jar包,以便在代码中使用jdbc的相关类和方法。
常用的jdbc jar包有mysql-connector-java、ojdbc等,根据所使用的数据库类型选择相应的jar包。
二、加载数据库驱动加载数据库驱动是使用jdbc连接数据库的第一步。
不同的数据库有不同的驱动类,需要根据所使用的数据库类型加载相应的驱动类。
加载驱动的方式有两种:一种是使用Class.forName()方法加载驱动类,另一种是使用DriverManager.registerDriver()方法注册驱动类。
三、建立数据库连接建立数据库连接是使用jdbc连接数据库的第二步。
在建立数据库连接之前,需要先获取数据库连接所需的连接信息,包括数据库的URL、用户名和密码。
数据库的URL是连接数据库的唯一标识,用户名和密码用于验证用户身份。
通过调用DriverManager.getConnection()方法,并传入连接信息参数,即可建立数据库连接。
四、执行数据库操作建立数据库连接之后,就可以执行数据库操作了。
数据库操作包括数据的增删改查等操作。
在执行数据库操作之前,需要创建Statement或PreparedStatement对象,并使用这些对象执行相应的SQL语句。
Statement对象用于执行静态SQL语句,而PreparedStatement对象用于执行带有参数的预编译SQL语句。
执行SQL语句后,可以通过ResultSet对象获取查询结果。
jdbc连接数据库的四个步骤如上所述,其中第一步是引入jdbc相关的jar包,第二步是加载数据库驱动,第三步是建立数据库连接,第四步是执行数据库操作。
通过这四个步骤,可以实现使用jdbc连接数据库,进行数据的增删改查等操作。
在使用jdbc连接数据库时,需要注意以下几点:1. 引入的jdbc jar包需要与所使用的数据库类型对应,否则无法正常连接数据库。
JDBC连接MySQL
JDBC连接MySQL经典方案最近在学习数据库开发的一些实例,这里浅谈一下用JDBC连接数据库MySQL(当然也可以连接SQL Sever或Oracle了,只是我更喜欢开源软件,同时也更简单)。
首先正确安装好MySQL,建立好数据库studentinfomysql>create database studentinfo;然后编写java代码,ConnectToMySQL.javaimport java.sql.*;public class ConnectToMySQL {public static Connection getConnection() throws SQLException ,ng.ClassNotFoundException{String url = "jdbc:mysql://localhost:3306/studentinfo";Class.forName("com.mysql.jdbc.Driver");String userName = "root";String password = "";Connection con = DriverManager.getConnection(url,userName,password); return con;}public static void main(String[] args) {try{Connection con = getConnection();Statement sql = con.createStatement();sql.execute("drop table if exists student");sql.execute("create table student(id int not null auto_increment,name varchar(20) not null default 'name',math int not null default 60,primary key(id));");sql.execute("insert student values(1,'AAA','99')");sql.execute("insert student values(2,'BBB','77')");sql.execute("insert student values(3,'CCC','65')");String query = "select * from student";ResultSet result = sql.executeQuery(query);System.out.println("Student表数据如下:");System.out.println("---------------------------------");System.out.println("学号"+" "+"姓名"+" "+"数学成绩");System.out.println("---------------------------------");int number;String name;String math;while(result.next()){number = result.getInt("id");name = result.getString("name");math = result.getString("math");System.out.println(number + " " + name + " " + math);}sql.close();con.close();}catch(ng.ClassNotFoundException e){System.err.println("ClassNotFoundException:" + e.getMessage()); }catch(SQLException ex){System.err.println("SQLException:" + ex.getMessage());}}}要注意的是使用MySQL数据库,需要用到对应的JDBC驱动程序mysql-connector-java-5.0.3import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;import java.sql.ResultSet;import java.sql.Statement;import java.sql.*;public class BaseConnection {private Connection con = null;protected Connection getCon(){ResultSet rs=null;Statement stmt = null;try {Class.forName("org.gjt.mm.mysql.Driver");String url="jdbc:mysql://192.168.0.10/数据库名?user=USR&password=PWD";conn = DriverManager.getConnection(url);stmt = conn.createStatem ent();} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}return con;}}1.把 mysql-connector-java-5.0.3-bin.jar放到%JAVA_HOME%\jre\lib\ext下2.访问类:package mysqldb;import java.sql.*;public class MysqlCon {private static String DriverName = "org.gjt.mm.mysql.Driver";private String dbURL = "jdbc:mysql://localhost/test";private String dbuser = "root";private String dbpassword = "";private Connection conn;private Statement stmt;private ResultSet rs;public MysqlCon(){try {Class.forName(DriverName).newInstance();conn = DriverManager.getConnection(dbURL,dbuser,dbpassword);stmt = conn.createStatement();String sql = "select * from worker";rs = stmt.executeQuery(sql);while(rs.next()){System.out.println(rs.getString(1));}} catch (InstantiationException e) {// TODO 自动生成catch 块e.printStackTrace();} catch (IllegalAccessException e) {// TODO 自动生成catch 块e.printStackTrace();} catch (ClassNotFoundException e) {// TODO 自动生成catch 块e.printStackTrace();} catch (SQLException e) {// TODO 自动生成catch 块e.printStackTrace();}}}package interphase;import java.sql.ResultSet;import java.sql.SQLException;import java.util.Vector;import javax.swing.JFrame;import javax.swing.JPanel;import javax.swing.JScrollPane;import javax.swing.JTable;import javax.swing.table.AbstractTableModel;import mysqldb.MysqlCon;public class ShowRS {private AbstractTableModel atm;private JTable jtable;private Vector vector;private JScrollPane jsp;private String title[]={"职工号","职工名","性别","出生日期","工资"}; private MysqlCon mysqlcon;private JFrame frame;public ShowRS(){vector = new Vector();atm = new AbstractTableModel(){public int getColumnCount() {return title.length;}public int getRowCount() {return vector.size();}public Object getValueAt(int rowIndex, int columnIndex) {if(!vector.isEmpty())return ((Vector)vector.elementAt(rowIndex)).elementAt(columnIndex); elsereturn null;}//取得单元格中的属性值public String getColumnName(int columnIndex){return title[columnIndex];}//数据模型不可编辑,该方法设置为空public void setValueAt(){}//取得列所属对象类public Class getCoumnClass(int c){return getValueAt(0,c).getClass();}//设置单元格不可编辑,为缺省实现public boolean isCellEditable(int row,int column){return false;}};jtable = new JTable(atm);jtable.setToolTipText("显示全部查询结果");jtable.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);jtable.setCellSelectionEnabled(false);jtable.setShowVerticalLines(true);jtable.setShowHorizontalLines(true);jsp = new JScrollPane(jtable);mysqlcon = new MysqlCon();vector.removeAllElements();atm.fireTableDataChanged();try {ResultSet rs = mysqlcon.getResultSet();while(rs.next()){Vector rec_vector = new Vector();rec_vector.addElement(rs.getString(1));rec_vector.addElement(rs.getString(2));rec_vector.addElement(rs.getString(3));rec_vector.addElement(rs.getDate(4));rec_vector.addElement(new Float(rs.getFloat(5)));vector.addElement(rec_vector);}} catch (SQLException e) {// TODO 自动生成catch 块e.printStackTrace();}atm.fireTableDataChanged();frame = new JFrame();frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);frame.add(jsp);frame.setSize(400,300);frame.setVisible(true);}}教程由JAVA中文网整理校对发布()JDBC连接MySQL加载及注册JDBC驱动程序Class.forName("com.mysql.jdbc.Driver");Class.forName("com.mysql.jdbc.Driver").newInstance();JDBC URL 定义驱动程序与数据源之间的连接标准语法:<protocol(主要通讯协议)>:<subprotocol(次要通讯协议,即驱动程序名称)>:<data source identifier(数据源)>MySQL的JDBC URL格式:jdbc:mysql//[hostname][:port]/[dbname][?param1=value1][¶m2=value2 ]….示例:jdbc:mysql://localhost:3306/sample_db?user=root&password=your_passwor d常见参数:user 用户名password 密码autoReconnect 联机失败,是否重新联机(true/false)maxReconnect 尝试重新联机次数initialTimeout 尝试重新联机间隔maxRows 传回最大行数useUnicode 是否使用Unicode字体编码(true/false)characterEncoding 何种编码(GB2312/UTF-8/…)relaxAutocommit 是否自动提交(true/false)capitalizeTypeNames 数据定义的名称以大写表示建立连接对象Stringurl="jdbc:mysql://localhost:3306/sample_db?user=root&password=your_pa ssword";Connection con = DriverManager.getConnection(url);建立SQL陈述式对象(Statement Object)Statement stmt = con.createStatement();执行SQL语句executeQuery()String query = "select * from test";ResultSet rs=stmt.executeQuery(query);结果集ResultSetwhile(rs.next()){rs.getString(1);rs.getInt(2);}executeUpdate()String upd="insert into test (id,name) values(1001,xuzhaori)";int con=stmt.executeUpdate(upd);execute()示例:try{}catch(SQLException sqle){}finally{}Java类型和SQL类型技术手册P421PreparedStatement(预编语句)PreparedStatement stmt = conn.prepareStatement("insert into test(id,name)values(?,?)");stmt.setInt(1,id);stmt.setString(2,name);注:一旦设定语句的参数值后,就可以多次执行改语句,直到调用clearParameters()方法将他清除为止CallableStatement(预储程序)技术手册P430JDBC2.0使用ResultSet对象中的光标上下自由移动Statement stmt = con.createStatement (ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);ResultSet rs=stmt.executeQuery("select * from test");public Statement createStatement(int resultSetType,int resultSetConcuttency) throws SQLExceptionresultSetTypeTYPE_FORWARD_ONLY 只能使用next()方法。
jdbc访问数据库的基本步骤
jdbc访问数据库的基本步骤访问数据库的基本步骤如下:1. 加载驱动程序:通过Class.forName()方法加载数据库驱动程序,例如加载MySQL驱动程序:`Class.forName("com.mysql.jdbc.Driver")`。
2. 创建数据库连接:通过DriverManager.getConnection()方法创建与数据库的连接。
需要指定数据库的URL、用户名和密码,例如:`Connection connection =DriverManager.getConnection(url, username, password)`。
3. 创建Statement对象:通过Connection对象的createStatement()方法创建Statement对象,用于执行SQL语句,例如:`Statement statement = connection.createStatement()`。
4. 执行SQL语句:使用Statement对象的executeUpdate()方法执行SQL语句,例如:`int result =statement.executeUpdate(sql)`。
可以执行增删改操作。
5. 处理查询结果:如果执行的是查询语句,使用Statement对象的executeQuery()方法执行查询,并使用ResultSet对象获取结果集,例如:`ResultSet resultSet =statement.executeQuery(sql)`。
6. 关闭数据库连接:使用Connection对象的close()方法关闭数据库连接,例如:`connection.close()`。
使用JDBC连接Mysql数据库会出现的问题总结
使⽤JDBC连接Mysql数据库会出现的问题总结⾸先理清⼏个概念:JDBC:java数据库连接,是Orical公司的指定的⼀套规范接⼝java数据库驱动:JDBC的实现类,由相应的数据库⼚商提供,可以通过驱动去操作不同的数据库在java-数据库这⾥,jdbc-api中的所有包都是java.sql或者javax.sqlJDBC的操作步骤:(1)建⽴数据库和表(2)创建项⽬(3)导⼊驱动jar包(4)注册驱动Class.forName("com.mysql.jdbc.Driver");(5)获取连接Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:端⼝号/项⽬名", "登录名", "密码");前⾔最近安装了⼀个 mysql 8.0 版本的数据库,在程序中连接的时候可谓是状况不断。
之前也会遇到⼀些问题,这⾥就对使⽤ JDBC 连接mysql 会出现的问题做⼀个汇总。
在此之前说明⼀下环境:开发⼯具:IDEAmysql版本: 8.0.12 for Win64 on x86_64 (MySQL Community Server - GPL)mysql驱动包:8.0.12驱动包URL 的改变异常信息Loading class com.mysql.jdbc.Driver. This is deprecated. The new driver class is com.mysql.cj.jdbc.Driver. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary.原因通过异常我们可以发现,新的驱动url是com.mysql.cj.jdbc.Driver,经过在⽹上查阅资料发现,从 mysql6开始,驱动包开始使⽤新的驱动 url。
jdbc的六个步骤
jdbc的六个步骤
JDBC(Java Database Connectivity)是一种用于连接和操作数据库的 Java API。
它提供了一组标准的接口和类,使得 Java 程序能够与各种不同类型的数据库进行交互。
使用 JDBC 进行数据库操作通常包括以下六个步骤:
1. 加载和注册 JDBC 驱动程序:在使用 JDBC 之前,需要先加载并注册相应数据库的驱动程序。
这可以通过在代码中使用 Class.forName()方法来实现,传递数据库驱动程序的类名作为参数。
2. 创建数据库连接:使用 DriverManager 类的 getConnection()方法来创建与数据库的连接。
需要提供数据库的 URL、用户名和密码等连接信息。
3. 创建 Statement 对象:通过连接对象创建 Statement 对象,用于执行 SQL 语句。
4. 执行 SQL 语句:使用 Statement 对象的 executeQuery()或 executeUpdate()方法来执行 SQL 查询或更新操作。
5. 处理结果:如果执行的是查询操作,可以使用 ResultSet 对象来获取查询结果。
通过循环遍历 ResultSet 对象,可以获取每一行的数据。
6. 关闭资源:在完成数据库操作后,需要关闭连接、 Statement 和 ResultSet 对象,释放相关资源。
这六个步骤是使用 JDBC 进行数据库操作的基本流程。
需要根据具体的数据库类型和需求,适当地调整代码和参数。
数据库连接三种方法
JAVA与数据库连接方法(一)用JAVA连接数据库主要有两种方式,一是用JDBC-ODBC桥来连接,二是用相关厂商提供的相应驱动程序来连接,首先谈谈第一种连接。
JDBC-ODBC桥接器是用JdbcOdbc.Class和一个用于访问ODBC驱动程序的本地库实现的。
对于WINDOWS平台,该本地库是一个动态连接库DLL(JDBCODBC.DLL)。
由于JDBC在设计上与ODBC很接近。
在内部,这个驱动程序把JDBC的方法映射到ODBC调用上,这样,JDBC就可以和任何可用的ODBC驱动程序进行交互了。
这种桥接器的优点是,它使JDBC目前有能力访问几乎所有的数据库。
通行方式如图所示:应用程序---JDBC API---JDBC-ODBC---ODBC API---ODBC层---数据源具体操作方法为:首先打开控制面板的管理工具,打开数据源(ODBC),在用户DSN里面添加数据源(即你要连接的数据库的名字),在这里假定连接SQL SERVER2000的GoodsSupply数据库。
名称填写你要连接的数据库的名称(GoodsSupply),然后逐步设置,如果选用了使用SQL-SERVER密码认证的话,就要输入相应的用户名及密码连接到数据库。
一路下一步设置完成。
在JAVA里面编写程序进行测试,在这里我的程序是让用户输入任意的表名与与列名,把该列的所有数据输出。
源代码如下:import java.io.BufferedReader;import java.io.InputStreamReader;import java.sql.*;public class ODBCBridge {public static void main(String[] args) {String url="jdbc:odbc:GoodsSupply";Statement sm=null;String command=null;ResultSet rs=null;String tableName=null;String cName=null;String result=null;BufferedReader input=new BufferedReader(new InputStreamReader(System.in)); try {try {Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); //加载驱动}catch(ClassNotFoundException e){System.out.println("Can not load Jdbc-Odbc Bridge Driver");System.err.print("ClassNotFoundException:");System.err.println(e.getMessage());}Connection con=DriverManager.getConnection(url,"USER","PASSWORD"); //使用SQL-SERVER2000认证DatabaseMetaData dmd=con.getMetaData(); //DMD为连接的相应情况System.out.println("连接的数据库:"+dmd.getURL());System.out.println("驱动程序:"+dmd.getDriverName());sm=con.createStatement();System.out.println("输入表名");tableName=input.readLine();while(true) {System.out.println("输入列名(为空时程序结束):");cName=input.readLine();if(cName.equalsIgnoreCase(""))break;command="select "+cName+" from "+tableName;rs=sm.executeQuery(command); //执行查询if(!rs.next())System.out.println("表名或列名输入有误");else {System.out.println("查询结果为:");do{result=rs.getString(cName);//数据库语言设置为中文,不用转换编码//result=new String(result.getBytes("ISO-8859-1"),"GB2312"); System.out.println(result);}while(rs.next());}}}catch(SQLException ex) {System.out.println("SQLException:");while(ex!=null) {System.out.println("Message:"+ex.getMessage());ex=ex.getNextException();}}catch(Exception e) {System.out.println("IOException");}}}JAVA与数据库连接方法(二)现在介绍第二种方法,用关厂商提供的相应驱动程序来连接。
JDBC连接数据库6个步骤
JDBC连接数据库6个步骤JDBC(Java Database Connectivity)是Java语言连接数据库的一种标准API,它提供了一组用于访问和操作数据库的接口。
在使用JDBC 连接数据库时,一般需要经过以下6个步骤:1.加载数据库驱动程序:``````2.建立数据库连接:加载驱动程序后,需要获取一个数据库连接。
在JDBC中,可以通过DriverManager类的getConnection(方法来创建一个数据库连接对象。
该方法接受三个参数:数据库URL、用户名和密码。
数据库URL指定了要连接的数据库的位置和其他连接参数。
例如,如果要连接localhost上的名为test的MySQL数据库,可以使用如下代码:```String url = "jdbc:mysql://localhost:3306/test";String username = "root";String password = "password";Connection connection = DriverManager.getConnection(url, username, password);```3. 创建Statement对象:创建Statement对象用于执行SQL语句。
Statement是JDBC中用于发送静态SQL语句的对象。
可以通过调用Connection对象的createStatement(方法来创建一个Statement对象。
例如:```Statement statement = connection.createStatement(;```4.执行SQL语句:通过Statement对象的executeQuery(方法来执行SQL查询语句。
该方法返回一个ResultSet对象,用于保存查询结果。
例如,可以执行一个简单的查询语句并遍历结果集:```String sql = "SELECT * FROM students";ResultSet resultSet = statement.executeQuery(sql);while(resultSet.next()String name = resultSet.getString("name");int age = resultSet.getInt("age");//处理查询结果```除了executeQuery(方法,Statement对象还提供了其他执行SQL语句的方法,如executeUpdate(用于执行更新操作。
JAVA使用JDBC连接数据库的几种方式
JAVA使用JDBC连接数据库的几种方式JDBC(Java Database Connectivity)是Java编程语言用于连接数据库的一种标准API。
它提供了一种访问和操作不同类型数据库的方法。
在JDBC中,有几种不同的方式可以连接数据库。
下面是常见的几种方式以及它们的详细介绍。
1.使用JDBC驱动程序连接数据库2. DriverManager类连接数据库DriverManager是一个Java类,用于管理JDBC驱动程序。
它提供了一种简单的方法来注册和获取特定驱动程序的连接。
使用DriverManager 连接数据库时,首先需要加载驱动程序,并使用驱动程序的URL、用户名和密码创建连接。
然后可以使用这个连接执行SQL查询和更新操作。
3. DataSource接口连接数据库DataSource是一个接口,用于从数据库连接池获取连接。
连接池是一组预先创建的数据库连接,可以重复使用,从而提高应用程序的性能。
通过使用DataSource接口,可以通过配置连接池的方式来连接和管理数据库连接。
这种方式通常适用于大型应用程序或需要高并发连接的场景。
4. 使用JNDI(Java Naming and Directory Interface)连接数据库JNDI是Java提供的一种用于在Java应用程序中查找和访问命名服务的API。
通过使用JNDI,可以在应用程序中配置数据库连接信息,并使用统一的方式访问数据库。
这种方式通常适用于企业级应用程序,其中数据库连接信息可以统一管理。
5.使用第三方库连接数据库除了使用JDBC标准API连接数据库,还可以使用一些第三方库来简化数据库访问。
例如,Hibernate是一个流行的Java持久化框架,它提供了一种简单的方式来与数据库进行交互。
使用Hibernate,可以通过简单的配置来连接和管理数据库。
总结:上述是几种使用JDBC连接数据库的方式。
每种方式都有自己的优势和适用场景。
使用JDBC分别利用Statement和PreparedStatement来对MySQL数。。。
使⽤JDBC分别利⽤Statement和PreparedStatement来对MySQL数。
⼀、MySQL数据库的下载及安装点击DOWNLOADS,拉到页⾯底部,找到MySQL Community(GPL)Downloads,点击选择下图中的MySQL Community Server选择想要的版本进⾏下载之后的步骤,因为本⼈已经安装过MySQL数据库,⽽卸载重装会⽐较⿇烦,卸载不⼲净会导致新的装不上,所以可以参考下⾯的博客,因为官⽹的改动,前⾯的部分已经与该博客不符,按照本⼈在上⾯的介绍寻找即可下⾯是数据库可视化⼯具Navicat的下载及破解教程⼆、使⽤JDBC利⽤Statement来对MySQL数据库进⾏简单的增删改查JDBC:Java DataBase Connectivity可以为多种关系型数据库DBMS提供统⼀的访问⽅式,⽤java来操作数据库。
Java程序通过JDBC来操作JDBC DriverManager 来操作数据库驱动程序(如Mysql驱动程序),进⽽操作数据库(如Mysql数据库)。
1、JDBC API:提供各种访问接⼝三项功能:Java程序与数据库建⽴连接Java程序发送SQL语句给数据库数据库返回处理结果给Java程序三项功能具体通过下⾯类/接⼝实现DriverManager:管理JDBC驱动Connection:Java程序与数据库建⽴连接Statement( PreparedStatement⼦类):增删改查CallableStatement:调⽤数据库的存储过程/存储函数ResultSet: 数据库返回的结果集JDBC访问数据库的具体步骤a.导⼊驱动,加载具体的驱动类b.与数据库建⽴连接c.发送SQL,执⾏d.处理结果集(查询)驱动jar如mysql-connector-java-x.jar(其中x为具体的版本号)具体驱动类:如com.mysql.jdbc.Driver连接字符串数据库名、IP地址、端⼝号如:jdbc:mysql://localhost:3306/数据库实例名Connection产⽣操作数据库的对象connection.createStatement():产⽣Statementconnection.prepareStatement():产⽣PreparedStatementconnection.prepareCall():产⽣CallableStatementResultSet: 数据库返回的结果集 select * from xxx(表名)ResultSet rs=null;rs.next();1、下移2、判断下移后的元素是否有数据如果不为空:返回true(有数据)如果为空:返回false(⽆数据)rs.previous():1、上移2、判断上移后的元素是否有数据如果不为空:返回true(有数据)如果为空:返回false(⽆数据)rs.getXXX(字段名|下标):获取rs指向⾏的数据Statement操作数据库增删改:executeUpdate(sql)查:executeQuery(sql)实例在Navicat建表如图原码如下package JDBCDemo;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;public class JDBCDemo {private static final String URL="jdbc:mysql://localhost:3306/mysql?serverTimezone=UTC&characterEncoding=utf-8"; private static final String USERNAME="root";private static final String PWD="vayne";public static void update(){Statement stmt=null;Connection connection=null;try {//a.导⼊驱动,加载具体的驱动类Class.forName("com.mysql.cj.jdbc.Driver");//b.与数据库建⽴连接connection = DriverManager.getConnection(URL,USERNAME,PWD);//使⽤Ctrl+1,快速⽣成值来获取Connection//c.发送SQL,执⾏(增删改、查)stmt = connection.createStatement();//增//String sql="insert into student values(1,'张志伟',19)";//删String sql="delete from student where name ='zzw'";//改//String sql="update student set name ='zzw' where id=1";//执⾏SQLint count=stmt.executeUpdate(sql);//返回值表⽰,增删改⼏条数据//处理结果if(count>0){System.out.println("操作成功");}}catch(ClassNotFoundException e) {e.printStackTrace();}catch(SQLException e) {e.printStackTrace();}catch(Exception e){e.printStackTrace();}finally {try {//先开的后关,后开的先关if(stmt!=null)stmt.close();if(connection !=null)connection.close();}catch(SQLException e) {e.printStackTrace();}finally {}}}public static void query() {Statement stmt=null;Connection connection=null;ResultSet rs=null;try {//a.导⼊驱动,加载具体的驱动类Class.forName("com.mysql.cj.jdbc.Driver");//b.与数据库建⽴连接connection = DriverManager.getConnection(URL,USERNAME,PWD);//使⽤Ctrl+1,快速⽣成值来获取Connection//c.发送SQL,执⾏(增删改、查)stmt = connection.createStatement();//查//String sql="select name,age from student";//模糊查询String aname="x";String sql="select * from student where name like'%"+aname+"%'";//执⾏SQL,增删改是executeUpdate(sql),查是executeQuery(sql)rs=stmt.executeQuery(sql);//返回值表⽰,增删改⼏条数据//处理结果while(rs.next()) {String sname=rs.getString("name");int sage=rs.getInt("age");System.out.println("姓名:"+sname+"年龄"+sage);}}catch(ClassNotFoundException e) {e.printStackTrace();}catch(SQLException e) {e.printStackTrace();}catch(Exception e){e.printStackTrace();}finally {try {//先开的后关,后开的先关if(rs!=null)rs.close();if(stmt!=null)stmt.close();if(connection !=null)connection.close();}catch(SQLException e) {e.printStackTrace();}finally {}}}public static void main(String[] args) {//update();query();}}增和查改和查删和查模糊查询String aname="x";String sql="select * from student where name like'%"+aname+"%'";在表中添加如图实现模糊查询三、使⽤JDBC利⽤PreparedStatement来对MySQL数据库进⾏简单的增删改查PreparedStatement操作数据库因为PreparedStatement是Statement的⼦类因此:增删改:executeUpdate(sql)查:executeQuery(sql)赋值操作:setXXX();实例原码如下package JDBCDemo;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;public class JDBCPrepareDemo {private static final String URL="jdbc:mysql://localhost:3306/mysql?serverTimezone=UTC&characterEncoding=utf-8"; private static final String USERNAME="root";private static final String PWD="vayne";public static void update(){PreparedStatement pstmt=null;Connection connection=null;try {//a.导⼊驱动,加载具体的驱动类Class.forName("com.mysql.cj.jdbc.Driver");//b.与数据库建⽴连接connection = DriverManager.getConnection(URL,USERNAME,PWD);//使⽤Ctrl+1,快速⽣成值来获取Connection//c.发送SQL,执⾏(增删改、查)//增//String sql="insert into student values(?,?,?)";//删String sql="delete from student where name ='zzw'";//改//String sql="update student set name ='zzw' where id=66";//执⾏SQLpstmt = connection.prepareStatement(sql);//预编译//pstmt.setInt(1, 66);//pstmt.setString(2, "六六⼤顺");//pstmt.setInt(3, 6);int count=pstmt.executeUpdate();//返回值表⽰,增删改⼏条数据//处理结果if(count>0){System.out.println("操作成功");}}catch(ClassNotFoundException e) {e.printStackTrace();}catch(SQLException e) {e.printStackTrace();}catch(Exception e){e.printStackTrace();}finally {try {//先开的后关,后开的先关if(pstmt!=null)pstmt.close();if(connection !=null)connection.close();}catch(SQLException e) {e.printStackTrace();}finally {}}}public static void query() {PreparedStatement pstmt=null;Connection connection=null;ResultSet rs=null;try {//a.导⼊驱动,加载具体的驱动类Class.forName("com.mysql.cj.jdbc.Driver");//b.与数据库建⽴连接connection = DriverManager.getConnection(URL,USERNAME,PWD);//使⽤Ctrl+1,快速⽣成值来获取Connection//c.发送SQL,执⾏(增删改、查)//查String sql="select name,age from student";//模糊查询//String sql="select * from student where name like ?";//执⾏SQL,增删改是executeUpdate(sql),查是executeQuery(sql)pstmt = connection.prepareStatement(sql);//预编译//pstmt.setString(1, "%x%");rs=pstmt.executeQuery();//返回值表⽰,增删改⼏条数据//处理结果while(rs.next()) {String sname=rs.getString("name");int sage=rs.getInt("age");System.out.println("姓名:"+sname+"年龄"+sage);}}catch(ClassNotFoundException e) {e.printStackTrace();}catch(SQLException e) {e.printStackTrace();}catch(Exception e){e.printStackTrace();}finally {try {//先开的后关,后开的先关if(rs!=null)rs.close();if(pstmt!=null)pstmt.close();if(connection !=null)connection.close();}catch(SQLException e) {e.printStackTrace();}finally {}}}public static void main(String[] args) {update();query();}}增和查改和查删和查模糊查询String sql="select * from student where name like ?";//预编译//执⾏SQL,增删改是executeUpdate(sql),查是executeQuery(sql)pstmt = connection.prepareStatement(sql);pstmt.setString(1, "%x%");在表中添加如图实现模糊查询四、Statement和PreparedStatement的⽐较推荐使⽤PreparedStatement,原因如下:1、编码更加简便(避免了字符串拼接)如:int id =1;String name="张志伟"stmt:String sql="insert into student(id,name) values("+id+",'"+name+"')"; stmt.executeupdate(sql);pstmt:String sql="insert into student(id,name) values(?,?)";pstmt=connection.prepareStatement(sql);//预编译sqlpstmt.setInt(1,id);pstmt.setString(2,name);2、可以提⾼性能(因为有预编译,预编译只编译⼀次)当添加n次,stmt:sql编译n次pstmt:sql只编译⼀次3、更加安全stmt:存在被sql注⼊的风险如:⽤户名:任意值 ’ or 1=1 --密码:任意值会登录成功select count(*) from login where uname='"+name+"' and upwd ='"+pwd+"';进⾏代⼊检验:select count(*) from login where uname='任意值 ’ or 1=1 --' and upwd ='任意值'; uname='任意值 ’为falseor1=1 为true--' and upwd ='任意值'; sql语句中--为注释,后⾯全是注释所以,where的结果是true,登录成功相当于select count(*) from loginsql注⼊:将客户输⼊的内容和开发⼈员的SQL语句混为⼀体pstmt:可以防⽌sql注⼊。
java连接mysql数据库(JDBC驱动)
Java连接mysql数据库一.软件下载Mysql下载版本:4.1.11/downloads/mysql/4.1.htmlJDBC驱动下载版本:3.1.8/downloads/connector/j/3.1.htmlMysql界面插件:mysql-front下载版本镜像:HongKong(我下回来安装就是中文版了)http://www.mysqlfront.de/download.html二.软件安装打开下载的mysql安装文件mysql-5.0.27-win32.zip,双击解压缩,运行“setup.exe”,出现如下界面:mysql安装向导启动,按“Next”继续选择安装类型,有“Typical(默认)”、“Complete(完全)”、“Custom (用户自定义)”三个选项,我们选择“Custom”,有更多的选项,也方便熟悉安装过程在“Developer Components(开发者部分)”上左键单击,选择“This feature, and all subfeatures, will be installed on local hard drive.”,即“此部分,及下属子部分内容,全部安装在本地硬盘上”。
在上面的“MySQL Server (mysql服务器)”、“Client Programs(mysql客户端程序)”、“Documentation (文档)”也如此操作,以保证安装所有文件。
点选“Change...”,手动指定安装目录。
填上安装目录,我的是“F:\Server\MySQL\MySQL Server 5.0”,也建议不要放在与操作系统同一分区,这样可以防止系统备份还原的时候,数据被清空。
按“OK”继续。
返回刚才的界面,按“Next”继续。
确认一下先前的设置,如果有误,按“Back”返回重做。
按“Install”开始安装。
正在安装中,请稍候,直到出现下面的界面这里是询问你是否要注册一个的账号,或是使用已有的账号登陆,一般不需要了,点选“Skip Sign-Up”,按“Next”略过此步骤。
简述jdbc访问数据库的一般流程
简述jdbc访问数据库的一般流程JDBC是Java中用于访问数据库的标准接口。
它可以让Java程序通过与数据库建立连接,执行SQL语句,并处理查询结果等操作。
一般情况下,JDBC访问数据库的流程如下:1. 加载数据库驱动首先,需要加载数据库的驱动程序。
不同的数据库有不同的驱动程序,例如MySQL的驱动程序是com.mysql.jdbc.Driver,Oracle的驱动程序是oracle.jdbc.driver.OracleDriver。
可以通过Class.forName方法或者DriverManager.registerDriver 方法来加载驱动程序。
2. 建立连接加载驱动程序之后,需要建立与数据库的连接。
可以使用DriverManager.getConnection方法来建立连接,需要传入数据库的URL、用户名和密码等信息。
连接成功后,就可以在Java程序中操作数据库了。
3. 执行SQL语句建立连接之后,可以使用Connection对象的createStatement方法或prepareStatement方法来创建一个Statement对象或PreparedStatement对象。
然后,可以使用这些对象执行SQL语句,例如查询、插入、更新或删除数据等操作。
4. 处理查询结果如果执行的SQL语句是查询操作,那么需要通过ResultSet对象来处理查询结果。
可以使用Statement对象或PreparedStatement对象的executeQuery方法来执行查询操作,然后使用ResultSet对象的getXXX方法来获取查询结果。
5. 关闭连接操作数据库完毕之后,需要关闭与数据库的连接,以释放相关资源。
可以使用Connection对象的close方法来关闭连接。
JDBC访问数据库的流程需要注意一些问题,例如SQL注入、事务处理、连接池等,这些问题都需要开发人员进行认真的考虑和处理。
JDBC如何连接mysql数据库附详细步骤
JDBC如何连接mysql数据库附详细步骤JDBC连接数据库在学习中是很重要的一个环节,今天给大家详细说明JDBC连接数据库需要的步骤1.加载驱动驱动包的下载地址/downloads/connector/j/到时候要将这个加载到项目中然后输入Class.forName("com.mysql.jdbc.Driver");.2.获取连接private static final String URL="jdbc:mysql://localhost:3306/studentprivate static final String NAME="root";private static final String PASSWORD="123456";Connection conn=DriverManager.getConnection(URL, NAME, PASSWORD);URL为路径;其中student为数据库名NAME 为用户名PASSWORD为密码3.通过数据库的连接完成String sql = "select sno,sname from st_profiles";rs = stmt.executeQuery(sql);while (rs.next()) {System.out.println(rs.getString("sno"));System.out.println(rs.getString("sname"));}4.关闭数据库rs.close();stmt.close();conn.close();通过以上步骤就可以完成JAVA与数据库的搭桥技术!第一次写可能写的不太好。
JDBC(连接数据库的四个主要步骤)
boolean flag = stmt.execute(String sql) ;
6、处理结果
两种情况:
1、执行更新返回的是本次操作影响到的记录数。
PreparedStatement pstmt = con.prepareStatement(sql) ;
CallableStatement cstmt =
con.prepareCall("{CALL demoSp(? , ?)}") ;
JDBC连接数据库
?创建一个以JDBC连接数据库的程序,包含7个步骤:
1、加载JDBC驱动程序:
在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),
这通过ng.Class类的静态方法forName(String className)实现。
协议:在JDBC中总是以jdbc开始
子协议:是桥连接的驱动程序或是数据库管理系统名称。
数据源标识:标记找到数据库来源的地址与连接端口。
例如:(MySql的连接URL)
jdbc:mysql:
//localhost:3306/test?useUnicode=true&characterEncoding=gbk ;
例如:
//连接MySql数据库,用户名和密码都是root
String url = "jdbc:mysql://localhost:3306/test" ;
String username = "root" ;
简述使用jdbc访问数据库的主要流程。
简述使用jdbc访问数据库的主要流程。
随着互联网的不断发展,数据的处理和存储已经成为整个信息系统中最为重要的部分之一。
数据库的使用已经成为了基本的方法之一,而访问数据库则需要使用一些特殊的工具,其中最为常用的就是JDBC。
JDBC是Java数据库连接的缩写,它是一个标准的Java API,用于访问各种数据库。
被广泛应用于各种应用程序和信息系统中。
那么,在使用JDBC时,我们需要注意哪些流程呢?1. 导入JDBC驱动程序使用JDBC访问数据库时,需要首先导入相应的JDBC驱动程序。
这个驱动程序是由不同的数据库厂商提供的。
在对不同的数据库进行操作时,我们需要拥有对应的JDBC驱动程序。
2. 加载驱动程序使用Class.forName()方法来加载驱动程序,并对其进行初始化,以确保JDBC驱动程序被正确地安装和使用。
3. 建立连接使用DriverManager类来建立数据库的连接。
使用DriverManager.getConnection()方法来建立连接。
在此期间,我们可以通过指定连接的URL、用户名、密码以及其他的连接属性来确定每个连接的选项。
4. 通过连接创建Statement对象使用Connection对象来创建Statement对象,Statement是一个用于执行SQL语句的对象。
可以使用Statement对象来查询、插入、修改和删除数据。
5. 执行SQL语句通过执行executeQuery()方法来执行查询语句,语句的执行结果将会返回ResultSet对象。
另一方面,如果需要执行插入、修改或删除语句时,则需要使用executeUpdate()方法。
6. 处理结果集当执行查询语句时,将会返回一个ResultSet对象,该对象包含了查询结果的所有行数。
可以通过ResultSet的next()方法从结果集中获取数据。
获取数据后,可以将其进行处理,如将其输出、写入到文件等。
7. 关闭连接和释放资源在使用完JDBC之后,需要使用Connection对象的close()方法来关闭与数据库的连接,并释放与该连接相关的所有资源。
第4章 JDBC与数据库应用
(3)建立Statement对象或PreparedStatement对象。
(4)执行SQL语句。 执行SQL查询○1 String sql=”select * from users”; ResultSet rs=stmt.executeQuery(sql); 执行insert,update,delete等语句,先定义sql ○2 stmt.executeUpdate(sql);
写入数据库
编写程序完成用户注册功能,即通过JDBC连接数据库,并向 users表中添加一条新记录。注册的资料包含姓名、密码、性别、 熟练开发语言、个人简介。
新知识点——Connection、Statement、ResultSet等对象的常用 方法
在Java语言中提供了丰富的类和接口用于数据库编程,利用它们 可以方便地进行数据的访问和处理。下面主要介绍Java.sql包中 提供的常用类和接口。
实现过程: 通过JDBC连接SQL Server的hncst数据库,实例文件为 exam4_2_sqlserver.jsp,具体步骤如下: 1.在Microsoft SQL Server的官网下载SQL Server JDBC 驱动 (不同版本的数据库对应不同驱动程序)。将下载好的驱动 sqljdbc.jar文件复制到网站的lib目录中,如图4-5,4-6所示。 2.将SQL Server的验证方式改为混合验证方式,并设置合法用 户名和密码。打开Microsoft SQL Server Management Studio Express,通过右键点击数据库“服务器属性”面板, 在“安全”选项里进行配置,重启SQL Server后生效,如图4-7 所示。
分页显示数据
JDBC连接数据库6个步骤
JDBC连接数据库6个步骤JDBC(Java Database Connectivity)是用于在Java应用程序和数据库之间进行交互的API。
它允许开发人员使用Java编程语言来访问各种关系型数据库,并执行SQL查询、更新和管理数据库事务等操作。
连接数据库是使用JDBC的第一步,以下是连接数据库的六个步骤。
1.加载JDBC驱动程序:``````2.建立数据库连接:一旦驱动程序加载完毕,就可以使用“DriverManager.getConnection(”方法来建立与数据库的连接。
该方法接受一个连接字符串和数据库连接的用户名和密码作为参数。
连接字符串包含数据库的URL、主机名、端口号和数据库名。
例如,连接MySQL数据库的连接字符串如下:```String url = "jdbc:mysql://localhost:3306/mydb";String username = "root";String password = "password";Connection conn = DriverManager.getConnection(url, username, password);```3. 创建Statement对象:在建立数据库连接后,可以使用创建Statement对象进行数据库查询和更新操作。
Statement对象用于执行SQL语句,并将结果返回给Java应用程序。
可以使用“Connection.createStatement(”方法创建Statement对象。
例如:```Statement stmt = conn.createStatement(;```4.执行SQL查询或更新:可以使用Statement对象执行SQL查询和更新操作。
执行查询操作时,可以使用“Statement.executeQuery(”方法执行SELECT语句并返回结果集。
jdbc连接的七个步骤
jdbc连接的七个步骤
嘿,咱今儿个就来聊聊 JDBC 连接的那七个步骤哈!你说这就好比
是搭积木,每一块都得放对地方,这房子才能稳稳当当立起来呀!
第一步,加载驱动。
这就好像是给汽车点火,没这一下,车子可跑
不起来呢!这驱动就是那关键的启动钥匙呀。
第二步,建立连接。
哎呀呀,这就好比是找到了去目的地的路,得
先有这条路,才能接着往下走呀。
第三步,创建语句对象。
这就像是给你准备好了画笔和颜料,接下
来就看你怎么发挥啦!
第四步,执行查询语句。
嘿,这就开始动手画啦,得画得漂亮才行呢!
第五步,处理结果集。
这就像是欣赏自己画出来的作品,得仔细看看,有啥问题赶紧改改。
第六步,关闭结果集。
就好像画完了把工具收拾好,下次还能用呀。
第七步,关闭连接。
这就好比是离开画室,得把门关好呀,不然风
一吹,可不就乱套啦!
你想想,要是这其中哪个步骤出了岔子,那不就跟搭积木少了一块
似的,整个就不稳啦!就拿加载驱动来说,要是没加载好,后面的步
骤不就都白搭了嘛。
再比如建立连接,这要是连不上,那不就跟走在路上迷路了一样嘛。
所以说呀,这七个步骤,每一个都重要得很呢!咱可得一个一个认真对待,不能马虎哟!就像咱过日子,每一件小事都做好了,这日子才能过得顺顺当当呀!可别小瞧了这小小的 JDBC 连接的七个步骤,它们背后可藏着大乾坤呢!你说是不是呀?。
第四章 使用JDBC连接数据库
4.2.2 Connection类
Connection类代表对特定数据库的连接。 在一个Connection的作用范围内,可以执行SQL 语句并返回结果。 1. 打开连接
打开URL=" jdbc:mysql://localhost/coursesystem" 的数据库。连接该数据库的用户名为root,口令为 root。 String url = " jdbc:mysql://localhost/coursesystem"; Connection con = DriverManager.getConnection(url, "root", "root");
第四章 使用JDBC连接数据库
本章主要内容
四种类型的JDBC驱动程序。 JDBC API中几个主要的接口(类)。 通过JDBC访问数据库的7个步骤。 事务操作。
4.1 JDBC概述
4.1.1 JDBC简介 JDBC(Java Database Connectivity,Java数 据库连接)是一个面向对象的应用程序接口 (API),是执行SQL语句的Java API,由一组用 Java语言编写的类与接口组成。 JDBC的最大特点是独立于具体的关系数据库。
4.3.4 创建Statement对象
Statement对象是一个用于发送查询语句并得到结 果集的对象,没有该对象就不能进行数据库的操 作。 由Connection的createStatement()方法创建,一 般使用下面的代码片段: Statement stmt= conn.createStatement();
4) 常见可选参数:
• user: 数据库用户名。 • password: 数据库密码。 • autoReconnect: 数据库连接丢失时,是否自动连接;取值为 true/false,默认为false。 • maxReconnect: 当autoReconnect=true时,此参数为尝试重 新连接次数,默认为3次。 • initialTimeout: 当autoReconnect=true时,此参数为尝试 重新连接前等待的秒数,默认为2秒。 • maxRows: 查询时返回的行数;默认为0,表示全部。 • useUnicode: 是否使用Unicode字体编码;取值为true/false, 默认为false。 • characterEncoding: 当useUnicode=true时,此参数设置为采 用何种编码,取值为GB2312/UTF-8/GBK等。
使用JDBC连接数据库(一)
使⽤JDBC连接数据库(⼀)JDBC是由java编程语⾔编写的类及接⼝组成,同时它为程序开发⼈员提供了⼀组⽤于实现对数据库访问的JDBC API,并⽀持SQL语⾔。
利⽤JDBC可以将JAVA代码连接到oracle、DB2、SQLServer、MYSQL等数据库,从⽽实现对数据库中的数据操作的⽬的。
⼀、JDBC简介JDBC全称为:Java Data Base Connectivity (java数据库连接),可以为多种数据库提供填统⼀的访问。
JDBC是sun开发的⼀套数据库访问编程接⼝,是⼀种SQL级的API。
它是由java语⾔编写完成,所以具有很好的跨平台特性,使⽤JDBC编写的数据库应⽤程序可以在任何⽀持java的平台上运⾏,⽽不必在不同的平台上编写不同的应⽤程序。
JDBC的主要功能如下:(1)建⽴与数据库或者其他数据源的链接(2)向数据库发送SQL命令(3)处理数据库的返回结果⼆、JDBC中常⽤类和接⼝连接到数据库(Connection)、建⽴操作指令(Statement)、执⾏查询指令(executeQuery)、获得查询结果(ResultSet)等。
1、驱动程序管理类(DriverManager)DriverManager类是JDBC的管理类,作⽤于⽤户和驱动程序之间。
它跟踪在可⽤的驱动程序,并在数据库和相应驱动程序之间建⽴连接。
另外,DriverManager类也处理诸如驱动程序登陆时间限制及登录和跟踪消息的显⽰事务。
对于简单的应⽤程序,⼀般程序员需要在此类中直接使⽤唯⼀的⽅法时DriverManager.getConnection()。
该⽅法将建⽴与数据库的链接。
JDBC允许⽤户调⽤DriverManager的⽅法getDriver()、getDrivers()和registerDriver()及Driver的⽅法connect().2、声明类(Statement)Statement对象⽤于将SQL语句发送到数据库中。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
本次预计讲解的知识点:
1、JDBC分类,并使用JDBC连接Mysqle操作
2、JDBC主要接口的使用没,并可以利用这些接口完成数据的操作
3、事务处理
4、批处理的使用
JDBC简介(理解)
JDBC(Java DataBase Connective)Java的数据库连接,JDBC本身提供的是一套与平台无关的数据库的操作标准。
所以在整个JDBC中充斥着大量的操作接口。
而且JDBC本身不是技术,而是一种服务。
由于JDBC 本身属于一个标准,所以一个数据库如果希望使用Java 进行程序开发的话,那么各个数据库的生产商必须实现这些标准——提供专门的数据库的操作包。
根据JDBC操作方式的不同,一共有以下三种常见形式:
·JDBC-ODBC桥连接:利用微软的ODBC技术进行操作
|- 操作过程:程序->JDBC--->ODBC--->数据库
|- 此方式属于Java默认支持的方式,但是由于其中间加入了ODBC端,所以性能很差
·JDBC连接:使用各个数据库生产商提供的数据库驱动程序
|- 操作过程:程序--->JDBC---> 数据库
|- 由于中间缺少了ODBC环节,所以性能将有着明显的提升
·JDBC网络连接:通过网络协议进行数据库的连接操作
一定要记住的是,虽然JDBC-ODBC方式不被使用,但是此种操作中由于是SUN默认支持的,所以JDBC的版本是最高的,但是如果使用的是纯粹的各个数据库生产商提供的驱动程序,那么肯定不会与最新的技术同步。
如果现在使用的是Eclipse的话,则需要在Build Path中配置此驱动程序的开发包。
此时配置完成驱动程序之后,就可以通过以下的接口和类进行JDBC操作了:
·类:DriverManager
·接口:Connection、PreparedStatement、Statement、ResultSet
1.1、JDBC操作步骤
JDBC本身是一个标准,所以其操作步骤是固定的,以后只需要修改很少一部分代码就可以达到不同数据库间的连接转换功能。
JDBC操作步骤:
数据库安装并配置完成之后,就可以按照以下的步骤进行数据库的操作了:
1.加载数据库驱动程序:各个数据库都会提供JDBC的驱动程序开发包,直接把JDBC操作所需
要的开发包(一般为*.jar或*.zip)直接配置到classpath路径即可。
2.连接数据库:肯定要使用连接地址。
根据各个数据库的不同,连接的地址也不同,此连接地址
将由数据库厂商提供,一般在使用JDBC连接数据库时都要求用户输入数据库连接的用户名
和密码,本章使用mysql数据库,所以用户名和密码为“root“,用户在取得连接之后才可以对数据库进行查询或更新操作。
3.使用语句进行数据库操作:数据库操作分为更新和查询两种操作,除了可以使用标准的SQL
语句之外,对于各个数据库也可以使用其自己提供的各种命令。
4.关闭数据库连接:数据库操作完毕之后需要关闭连接以释放资源,因为数据库的连接是非常
有限的。
1.2、配置数据库的驱动程序
数据库驱动程序是由各个数据库生产商提供,只要在JAVA中要想连接数据库,则肯定各个DB要有所支持。
mysql JDBC Driver常用的有两个: 一个是gjt(Giant Java Tree)组织提供的mysql驱动,其JDBC Driver名称(JAVA类名)为:org.gjt.mm.mysql.Driver详情请参见网站:;另一个是mysql官方提供的JDBC Driver,其JAVA类名为:com.mysql.jdbc.Driver ,
/downloads/,
进入其中的MySQL Connector/J区域下载。
此时直接修改CLASSPATH即可。
此时数据库驱动程序就安装完成了。
1.3、加载驱动程序
通过Class.forName()语句可以加载一个驱动程序。
Class实例化需要一个完整的包.类名称,此:“包.类”路径就应该是驱动程序的名称。
org.gjt.mm.mysql.Driver
com.mysql.jdbc.Driver,
(附:把“mysql-connector-java-5.1.20-bin.jar”通过WINRAR打开,找到
org/gjt/mm/mysql/Driver.class)
语法:public static Class<?> forName(String className)
throws ClassNotFoundException
没有发现类的错误,肯定是classpath配置有问题。
1.4、连接及关闭数据库
语法:public static Connection getConnection(String url,
String user,
String password)
此时,数据库已经正常连接,之后可以进行数据库的一系列的SQL语句操作了。
1.5 Statement接口(重点)
如果要进行数据库的操作,在JDBC中依然使用的是SQL语句完成,而用于执行这些SQL语句的接口就是Statement 接口了
但是如果使用Statement 接口操作的话也分为两种形式:
查询、更新,
为了方便起见,在mysql中建立以下的一张表完成数据库的更新。
如果要想增加数据则编写增加的SQL语句:
INSERT INTO 表名称(列名称1,列名称2,…) VALUES (值1,值2,…) ;
SQL是固定的,全部换成变量,则可以按照如下代码编写:
1.5.2数据库更新:
修改数据的SQL语法:
UPDATE 表名称SET 字段=值,字段=值,.. [WHERE 更新条件] 如果不写更新条件,表示的是全部数据都要更新。
删除数据的SQL语法如下:DELETE FROM 表名称[WHERE 删除条件]
DelDemo.java
在操作时使用Statement中的executeQuery()方法进行数据库的查询操作。
此方法返回值就是ResultSet接口。
语法:ResultSet executeQuery(String sql)throws SQLException
查询
1.7 PreparedStatement
使用Statement操作时,肯定要执行的是一条完整的SQL语句,执行之前是使用Connection 直接创建的。
就好比占座,证明此座已经有人了,但是在等待着人的到来。
Connection接口:
PreparedStatement prepareStatement(String sql) throws SQLException
通过以上方法可以得到一个PreparedStatement的一个接口实例。
之后使用一系列的setXxx()方法设置内容,根据位置设置。
如果执行更新语句的话,则会返回更新数据的记录。
注意点:关于日期输入问题:正常情况下都使用java.util.Date表示日期,但是在PreparedStatement 中如果要使用日期则必须使用java.sql.Date类型。
例:使用PreparedStatement执行数据库的插入操作
PreparedStatement的基本工作原理,插入时,先占
1.8 批处理
所谓批处理就是指所有的操作可以一次性的提交到数据库之中。
如果要使用批处理则需要Statement接口中的addBatch()方法
设4条记录是有关联的4条呢?
在使用批处理的操作发现,如果中间有一条语句出错,则默认情况下是将出错之前的代码进行提交,这是由于JDBC采用了自动的事务提交的方式才造成的后果。
如果此时进行事务处理的话,则需要按照如下方式进行:
1.取消自动提交:public void conn.setAutoCommit(false);
2.执行更新操作
3.如果没有错误,则提交事务 public void commit() throws SQLException
4.如果有错误,则进行回滚:public void rollback()throws SQLException。