• Java数据库连接技术——JDBC


      大家好,Java如何连接数据库。之前学过.net语言的数据库操作,感觉就是一通百通,大同小异。

      JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力。

        JDBC API (主要功能:与数据库建立连接、执行语句、处理结果):

          提供者:Sun公司

          内容:供程序员调用的接口与类,集成在java.sql和javax.sql(后面的x是extend,扩展的意思)。如:

            DriverManager类(管理各种不同的JDBC驱动),

            Connection接口(连接数据、传送数据),

            statement接口(执行SQL语句),

            ResultSet接口(根据statement返回的结果集,来处理结果)。

      编写步骤:

        1.加载JDBC驱动;

        2.创建数据库连接对象;

        3.创建命令对象statement,来执行SQL语句并返回结果集;

        4.ResultSet通过返回的结果集,来处理结果;

        5.关闭数据库连接,释放资源。

      举一个验证用户登录的例子吧:

      

    package jdbc;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.util.Scanner;
    
    /**
     * JDBC连接数据库.java
     * 2017-1-6 上午11:14:48
     * John
     */
    public class Test {
        public static void main(String[] args) {
            Scanner input=new Scanner(System.in);
            System.out.println("请输入用户名:");
            String username=input.next();
            System.out.println("请输入密码:");
            String userpwd=input.next();
            //1.加载JDBC驱动
            try {
                Class.forName("com.mysql.jdbc.Driver");//MySQL使用的驱动器  //oracle驱动器:oracle.jdbc.driver.OracleDriver
            } catch (ClassNotFoundException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            //2.创建数据库连接对象
            Connection conn=null;
            Statement stat=null;
            ResultSet rs=null;
            try {
                            //mysql连接URL编写格式为:jdbc:mysql://主机名称:连接端口/数据库名称
                  //oracle连接URL编写格式为: oracle jdbc:oracle:thin:@127.0.0.1:1521:pet
    String url="jdbc:mysql://localhost:3306/Pet"; conn=DriverManager.getConnection(url, "root","123456"); //3.创建命令对象statement stat=conn.createStatement(); //4.执行命令,并返回结果集 String sql="select count(1) as cnt from users where UserName='"+username+"' and userpwd='"+userpwd+"'"; rs=stat.executeQuery(sql); while(rs.next()){ int count=rs.getInt("cnt"); if (count==1) { System.out.println("登录成功!"); }else { System.out.println("登录失败!"); } } } catch (SQLException e) { //此处记住要对异常进行处理 // TODO Auto-generated catch block e.printStackTrace(); }finally{ //5.关闭数据库连接 try { conn.close(); stat.close(); rs=null; } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }

      以上是我的个人观点,有异议的地方望大家指正,共同学习,共同进步!

      

      

      

  • 相关阅读:
    打印杨辉三角C语言小程序
    奇怪的比赛蓝桥杯
    (转)Silverlight CoreCLR结构浅析
    试一试!
    (转)使用自定义行为扩展 WCF
    分组合并的使用
    多进程,多线程(转载)
    在 ASP.NET 网页中不经过回发而实现客户端回调(需要实现ICallbackEventHandler接口)
    读书笔记
    WCF学习笔记3(客户端内部运行机制分析)
  • 原文地址:https://www.cnblogs.com/yilinzi/p/yilinzi.html
Copyright © 2020-2023  润新知