新手学JAVA----走进JDBC

  • 什么是JDBC
  • 为什么要用JDBC
  • 怎么用JDBC

什么是JDBC?



JDBC(Java Data Base Connectivity, Java 数据库连接)是一种用于执行SQL语句的JavaAPI,可以为多种关系数据库提供统一访问。简单地说,JDBC 可做三件事:与数据库建立连接、发送 SQL 语句并处理结果。

为什么要用JDBC?



在没有JDBC之前,应用程序可以通过数据库厂商提供的API及SQL语句对数据库进行操作,如下图:

有了JDBC,向各种关系数据发送SQL语句就是一件很容易的事,换言之,有了JDBC API,就不必为方位MySQL数据库专门写一个程序,为访问Oracle数据库又专门写一个程序,或为访问SQLServer数据库又编写另一个程序,等等,程序员只需用JDBC API 写一个程序就够了,它可想相应的数据库发送SQL调用,同时将JAVA语言和JDBC结合起来使程序员不必为不同的平台编写不同的应用程序,只需写一遍程序就可以让它在任何平台上运行。如下图:

怎么用JDBC?



JDBC的主要功能如下:

  • 建立与数据库或其他数据源的连接
  • 向数据库发送SQL命令
  • 处理数据库的返回结果

下面通过一个例子来演示Java数据库一个用程序反问数据库的全过程。

import java.sql.*; //导入包
import java.sql.Connection;
import java.sql.DriverManager;

public class JDBCMain {

    // 数据库的链接
    private Connection con = null;
    private Statement st = null; // 执行SQL语句的对象
    private ResultSet rs = null; // 结果集对象

    public JDBCMain() {

        // 桥连接
        try {

            // 声明驱动程序
            String driver = "com.microsoft.sqlserver.jdbc.SQLServerDriver";

            // users就是数据源的名称
            String ds = "jdbc:sqlserver://localhost:1433;databaseName=JavaSpecial";

            // 数据源的登录名
            String user = "sa";

            // 数据源的密码
            String password = "123456";

            // 链接数据库
            Class.forName(driver); // 加载数据库的驱动程序

            con = DriverManager.getConnection(ds, user, password);

            if (con != null) {

                System.out.println("数据库链接成功!");
            }
        } catch (Exception e) {
            System.out.println("数据库连接失败!" + e.toString());
        }
    }

    /**
     * 普通查询
     * @param sqlQuery
     */
    public void query(String sqlQuery) {

        try {
            // Connection con = null;
            Statement st = con.createStatement(); // 得到Statement的实例
            ResultSet rs = st.executeQuery(sqlQuery); // 执行SQL语句,返回结果集

            // 当返回的结果集不为空是,并且还有记录时
            while (rs != null && rs.next()) {
                int stu_num = rs.getInt(1); // 获得当前记录的第1个字段的值
                String name = rs.getString("name"); // 获得当前记录中"name"字段的值
                int age = rs.getInt("age"); // 获得当前记录中"age"字段的值
                int math = rs.getInt("math"); // 获得当前记录中"math"字段的值
                int english = rs.getInt("english"); // 获得当前记录中"english"字段的值

                System.out.println("学号=" + stu_num + "\t 姓名=" + name + "\t 年龄="
                        + age + "\t 数学成绩=" + math + "\t 英语成绩=" + english);
            }

        } catch (Exception e) {
            // 抛出异常
            System.out.println("查询数据时出错" + e.toString());
        }
    }

    /**
     * /添加,删除,更新
     */
    public void add_update_Del(String sql) {
        try {
            Statement st = con.createStatement(); // 生成Statement对象
            int x = st.executeUpdate(sql); // 执行操作
            System.out.println("操作成功" + x);
        } catch (Exception e) {
            System.out.println("数据修改时有误" + e.toString());
        }

    }

    // 主程序
    public static void main(String[] args) {

        JDBCMain jc = new JDBCMain();

        // 查询
        String name = "张三";
        String sqlQuery = "select * from stu_info where name=‘" + name + "‘";
        jc.query(sqlQuery);

        //添加
        String sqlAdd ="insert into stu_info values(7,‘令仔‘,17,89,84)";
        jc.add_update_Del(sqlAdd);

        //更改
        String sqlUpdate ="update stu_info set math =95 where name =‘张三‘";
        jc.add_update_Del(sqlUpdate);

        //删除
        String sqlDelete ="delete from stu_info where name=‘张三‘";
        jc.add_update_Del(sqlDelete);
    }
}

下面是源代码下载的链接:JDBC数据库连接测试

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-19 04:39:29

新手学JAVA----走进JDBC的相关文章

【经验分享】新手学Java编程语言怎么入门?

新手学Java编程语言怎么入门?掌握语言基础是第一步,了解java基础知识,Java关键字.核心概念或者基本编码技术.掌握操作符.控制执行流程.访问权限控制.复用类.多态.接口.字符串.泛型.数组.容器深入研究.JavaI/O系统.枚举类型.并发以及图形化用户界面等内容. 为了帮助大家更轻松的学好java开发,给大家分享一套java开发学习资料,小编推荐一个学java开发技术的学习裙:三七四三二零二八二,无论你是大牛还是小白,是想转行还是想入行都可以来了解一起进步一起学习!裙内有开发工具,很多干

新手学JAVA(三)----StringBuilder类

上一篇文章新手学JAVA(二)----String类与StringBuffer类的区别中了解到,String的值是不可变的,这就导致 每次对String的操作都会生成新的String对象,不仅效率低下,而且大量浪费有限的内存空间,StringBuffer是可变 类,和线程安全的字符串操作类,任何对它指向的字符串的操作都不会产生新的对象. StringBuffer类和StringBuilder类功能基本相似.算是两个双胞胎. 下面主要说两点 第一点  线程安全 StringBuffer  线程安全

新手转行学java难吗?新手学java需要注意的6个方面!

新手转行在成都学java到底难不难,对于这个问题,我们专门做过一个调查,超过1000名已经在职的java从业者,其中有80%的程序员觉得学java不难,20%的程序员觉得前期有点难,其中对于50%自学的新手认为java很难学,遇到问题没人解答,又或者是答案太多,根本不知道哪个回答是正确的.所以,我们得出结论,能系统学习的,有老师指导的java课程学起来相对容易,而没有人指导,仅仅靠看视频学习的同学来说会无形中增加难度. 很多新手在准备转行学习java之前,在网上看到或听到很多不懂的人会说,jav

新手学Java笔记心得之Java基础

第一次学习Java,一些基本的常用的快捷方式和一些很基础的知识点(笔记比较零散比较乱) Java是一种既面向对象又可以跨平台的语言,即:编写一次,随处运行: Java不仅适用于单机应用程序和基于网络的程序,也可用于创建消费类设备的附件程序,如移动电话.掌上设备等. Java命名规范首字母可以是字母,下划线'_','$'符号后面加上任意多的数字,字母,下划线,'$'符号通常第一个单词的首字母小写,其后单词的 首字母大写.例如:myScore MyEclipse编写Java代码的快捷键(新手不推荐使

新手学JAVA(六)----处理随机性的数据

基础知识 实例 在我们的日常生活中会遇到很多随机性的事情,比如:摇奖,彩票,掷色子,这些都可以通过程序计算其中奖的概率.在JAVA的类库中,有一个专门操作这种随机性数据的类--Random类. 基础知识 Random类一般使用在那些随机性比较强的场合,因为这些场合都含有一种随机的特性,也就是使用同样的方法去操作数据,每次操作的结果都不一样. 下面是Random类的常用方法: 方法 表示 public boolean nextBoolean() 返回true或者是false public doub

新手学Java(一)——Equals和“==”的区别

一句话概括: 如果操作两边都是对象句柄,就比较两个句柄是否指向同一个对象.如果两边是基本类型,则比较的就是值. ==不属于任何类,而equals则是任何类(Java中)的一个方法. equals()是每个对象与生俱来的方法,因为所有类的最终基类就是Object(除去Object本身):而equals()是Object的方法之一. 我们可以这样比较: 1)Primitive1(基本类型)== Primitive2(基本类型) 2)Object1 Reference1(对象引用)== Object1

新手学JAVA(七)----Override VS Overload

一 Overload 二 Override 三 多态性 一. Overload 在同一个类中的许多方法可以拥有相同的名字,只要他们的参数声明不同即可,这种方法被称为重载. 举个例子: public class overload{ '''一个重则输出方法''' void print(){ System.out.println("Hello!"); } '''重载上面的输出方法,加上了参数''' void print(String name) { System.out.println(na

新手学JAVA(十一)-多线程----线程的生命周期

新建和就绪状态 运行状态和阻塞状态 线程死亡 当一个线程被创建并启动之后,并不是一开始就处于执行状态,已不是一直处于运行状态.线程也是有生命周期的,包括:创建(New).就绪(Runnable).阻塞(Blocked).运行(Running).死亡(Dead)五种状态.当线程运行时,也不可能一直霸占着CPU独自运行,而是一直在运行.就绪状态之间切换. 新建和就绪状态 当程序通过new创建一个线程时,这个线程就处于新建(New)状态了,不过这个时候该线程并没有表现出线程的任何特征,和其他的普通ja

新手学JAVA(二)----String类与StringBuffer类的区别

在Java中有两种字符串的操作:String类和StringBuffer类(缓冲字符串处理类). 下面先简单的说一下两者的区别. String类和StringBuffer类都提供了相应的方法实现字符串的操作,但二者略有不同. (1) String类 该类一旦产生一个字符串,其对象就不可变.String类的内容和长度是固定的.如果程序需要获得字符串的信息需要调用系统提供的各种字符串操作方法实现.虽然通过各种系统方法可以对字符串施加操作,但这并不改变对象实例本身,而是生成一个新的实例.系统为Stri