编写JDBC程序

package cn.itcast.jdbc.example;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Date;
public class Example01 {

    public static void main(String[] args) throws SQLException {

        //1.注册数据库的驱动
        //*在注册数据库驱动时,虽然DriverManager.registerDriver(new com. mysql.jdbc.Driver())方法可以完成,但会使数据库驱动被注册两次。因为Driver类的源码中,已经在静态代码块中完成了数据库驱动的注册。所以,为了避免数据库驱动被重复注册,只需要在程序中加载驱动类即可,具体加载方式如下所示。Class.forName("com.mysqk.jdbc.Driver");
        DriverManager.registerDriver(new com.mysql.jdbc.Driver());
      
        //2.通过 DriverManager获取数据库连接
        //可以看出,getConnection()方法中有三个参数,它们分别表示数据库url、登录数据库的用户名和密码。数据库山通常遵循如下形式的写法。jdbc:subprotocol:subname
        String url="jdbc:mysql://localhost:3306/chapter01";
        
        String usernames="root";

        String password="itcast";

        Connection conn=DriverManager.getConnection(url, username, password);


        //3.通过 Connection对象获取 Statement对象
        //通过Connection对象获取Statement对象。Connection创建Statement的方式有如下三种。
		//① createStatement(): 创建基本的Statement对象[执行静态SQL语句。]
		//② prepareStatement(): 创建PreparedStatement对象。[执行动态SQL语句。]
        Statement stmt= conn.createStatement();

        //4.使用 Statement执行SQL语句
        //①execute():可以执行任何SQL语句。
		//②executeQuery():通常执行查询语句,执行后返回代表结果集的Resultset对象。
		//③executeUpdate():主要用于执行DML和DDL语句。执行DML语句,如INSERT、UPDATE或 DELETE时,返回受SQL语句影响的行数,执行DDL语句返回0。
        String sql="select * from users";
        ResultSet rs=stmt.executeQuery(sql);

        //5、操作 ResultSet结果集
        System.out.println("id|name|password|email|birthday");
        while (rs.next()) {
            int id=rs.getInt("id");     //通过列名获取指定字段的值
            String name=rs.getString("name");
            String psw=rs.getString("password");
            String email=rs.getString("email");
            Date birthday=rs.getDate("birthday");
            System.out.println(id+"|"+name+"|"+psw+"|"+email+"|"+birthday); 
        }

        //6.回收数据库
        //回收数据库资源。关闭数据库连接,释放资源,包括关闭ResultSet、Statement和Connection等资源。
       if(rs!=null) {
		    try {
		        rs.close();
		    }catch (SQLException e) {
		        e.printStackTrace();
		    }
		    rs=null;
		}
		if(stmt!=null) {
		    try {
		        stmt.close();
		    }catch (SQLException e) {
		        e.printStackTrace();
		    }
		    stmt=null;
		}
		if(conn!=null) {
		    try {
		        conn.close();
		    } catch (SQLException e) {
		        e.printStackTrace();
		    }
		    conn=null;
		
		}
		    }
		}
扩展

DML(Data Manipulation Language)数据操纵语言:
适用范围:对数据库中的数据进行一些简单操作,如insert,delete,update,select等.

DDL(Data Definition Language)数据定义语言:
适用范围:对数据库中的某些对象(例如,database,table)进行管理,如Create,Alter和Drop.truncate

1.DML操作是需要手动控制事务的开启、提交(commit)和回滚的。
2.DDL操作是隐性提交的,不能rollback!

参考链接:http://www.itheima.com/news/20200115/174304.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是Java编写JDBC程序查询数据表的示例代码: ```java import java.sql.*; public class JdbcExample { static final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; static final String DB_URL = "jdbc:mysql://localhost/employee"; static final String USER = "root"; static final String PASS = "root"; public static void main(String[] args) { Connection conn = null; Statement stmt = null; try{ Class.forName("com.mysql.jdbc.Driver"); System.out.println("Connecting to database..."); conn = DriverManager.getConnection(DB_URL,USER,PASS); System.out.println("Creating statement..."); stmt = conn.createStatement(); String sql; sql = "SELECT id, name, age FROM employees"; ResultSet rs = stmt.executeQuery(sql); while(rs.next()){ int id = rs.getInt("id"); String name = rs.getString("name"); int age = rs.getInt("age"); System.out.print("ID: " + id); System.out.print(", Name: " + name); System.out.println(", Age: " + age); } rs.close(); stmt.close(); conn.close(); }catch(SQLException se){ se.printStackTrace(); }catch(Exception e){ e.printStackTrace(); }finally{ try{ if(stmt!=null) stmt.close(); }catch(SQLException se2){ } try{ if(conn!=null) conn.close(); }catch(SQLException se){ se.printStackTrace(); } } System.out.println("Goodbye!"); } } ``` 这个示例程序连接到一个名为"employee"的MySQL数据库,查询了其中一个名为"employees"的数据表,并输出了表中的ID、Name和Age字段的值。 当然,你需要根据自己的环境和需要进行相应的修改,比如JDBC驱动、数据库连接URL、用户名和密码等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值