数据库编程JDBC

JDBC(java databases connection):java数据库技术,即是由iava提供的与平台无关的数据库操作,其为资源操作,结束后,需要关闭数据库的连接;
JDBC规定了四种java数据库操作技术:
1、JDBC-ODBC技术
由JDBC间接操作ODBC进行与数据库的连接与操作,性能较差,但版本支持最为全面;
2、JDBC技术直接连接
有数据库生产商提供指定的数据库链接驱动,性能最好,但是支持版本不够全面;
3、JDBC网络连接
有专门的数据库网络连接指令进行指定主机的操作;
4、模拟数据库的网络协议,自己编写;

数据库操作的具体步骤
与数据库交互的接口和类都在java.sql类中;
1、向程序加载数据库驱动;
2、进行数据库连接(DriverManager类完成,connection表示连接)
3、进行数据的操作;
4、关闭数据库;

加载驱动程序
驱动程序,保存哎*.jar包内:

数据库连接
返回的使Connection类
.数据库的连接地址
jdbc:mysql:连接方式:主机名称:端口名称:数据库的SID
.数据库的用户名
.数据库的密码
链接步骤为:
使用DriverManager类获得Connection接口对象;

public static Connection getConnection(String url,
                       String user,
                       String password)
                                throws SQLException

Attempts to establish a connection to the given database URL. The DriverManager
 attempts to select an appropriate driver from the set of registered JDBC drivers.
Parameters:
url
 - a database url of the form jdbc:*subprotocol*:*subname*
user
 - the database user on whose behalf the connection is being made
password
 - the user's password
Returns:
a connection to the URL
Throws:
[SQLException]
 - if a database access error occurs

数据库操作

1、statement接口

public interface Statement extends Wrapper, AutoCloseable {
...}

Connection#createStatement 
  Statement createStatement() throws SQLException;
//取得satement()接口对象


int executeUpdate(String sql) throws SQLException;
//数据更新操作

 ResultSet executeQuery(String sql) throws SQLException;
//数据查询操作

数据更新操作

package db;
import java.sql.*;

public class DBS {
    private static final String DBDRIVER="com.mysql.jdbc.Driver";
    //驱动程序地址
    private static final String DBURL="jdbc:mysql://localhost:3306/login";
    //mysql链接地址   jdbc:mysql://localhost:3306/数据库名
    private static final String USER="root";
    //用户名
    private static final String PASSWORD="root";
    //密码
    private static Connection coo;
    public static void main(String args[]) throws Exception{
        //第一步加载数据库驱动程序,此时不需要实例化,因为会由容器自己负责管理
        Class.forName(DBDRIVER);

        //链接数据库
        coo=DriverManager.getConnection(DBURL,USER,PASSWORD);

        Statement stmt=coo.createStatement();
        String sql=" INSERT INTO NUMBER(ID,AGE) VALUES (11013412,22); ";
        int t= stmt.executeUpdate(sql);
        // 使用Statement 的excuteUpdate更新数据库,返回受影响的行数
        System.out.println(t);
        stmt.close();
        coo.close();

    }
}


数据查询操作
使用resultset 接口对象返回数据

 boolean next() throws SQLException;
package db;
import java.sql.*;

public class DBS {
    private static final String DBDRIVER="com.mysql.jdbc.Driver";
    //驱动程序地址
    private static final String DBURL="jdbc:mysql://localhost:3306/login";
    //mysql链接地址   jdbc:mysql://localhost:3306/数据库名
    private static final String USER="root";
    //用户名
    private static final String PASSWORD="root";
    //密码
    private static Connection coo;
    public static void main(String args[]) throws Exception{
        //第一步加载数据库驱动程序,此时不需要实例化,因为会由容器自己负责管理
        Class.forName(DBDRIVER);

        //链接数据库
        coo=DriverManager.getConnection(DBURL,USER,PASSWORD);

        Statement stmt=coo.createStatement();
        String sql="SELECT ID,AGE FROM number WHERE ID=\"11013435\";";//思考问什么要加上\..\;
        ResultSet result=stmt.executeQuery(sql);//返回ResultSet对象
        while (result.next()){
            System.out.println("ID:"+result.getString("ID")+"\n"+"AGE:"+result.getInt("AGE"));
//可以跟换为序号
        }
        // 使用Statement 的excuteUpdate更新数据库
        //System.out.println(t);
        result.close();
        stmt.close();
        coo.close();

    }
}

-----
ID:11013435
AGE:20

但是,statement对象介绍sql语句时,采用拼接字符串操作,其对逗号等较为敏感,容易出差;
2、PreparedStatement接口

public interface PreparedStatement extends Statement {
//statement的子接口
...
ResultSet executeQuery() throws SQLException;
// 返回ResultSet接口对象,查询操作

int executeUpdate() throws SQLException;
//返回改变的行数,更新操作
//注意以上两个方法不接收sql语句

---connection接口里
 PreparedStatement prepareStatement(String sql)
        throws SQLException;
}

更新操作

package db;
import java.sql.*;

public class DBS {
    private static final String DBDRIVER="com.mysql.jdbc.Driver";
    //驱动程序地址
    private static final String DBURL="jdbc:mysql://localhost:3306/login";
    //mysql链接地址   jdbc:mysql://localhost:3306/数据库名
    private static final String USER="root";
    //用户名
    private static final String PASSWORD="root";
    //密码
    private static Connection coo;
    public static void main(String args[]) throws Exception{
        //第一步加载数据库驱动程序,此时不需要实例化,因为会由容器自己负责管理
        Class.forName(DBDRIVER);

        //链接数据库
        coo=DriverManager.getConnection(DBURL,USER,PASSWORD);
        String sql="INSERT into number(ID,AGE) VALUES (?,?)";
        PreparedStatement pre=coo.prepareStatement(sql);
        pre.setString(1,"11031232");
        pre.setInt(2,27);
        int s=pre.executeUpdate();
        System.out.println(s);
        pre.close();
        coo.close();

    }
}
----

查找操作


package db;
import java.sql.*;

public class DBS {
  private static final String DBDRIVER="com.mysql.jdbc.Driver";
  //驱动程序地址
  private static final String DBURL="jdbc:mysql://localhost:3306/login";
  //mysql链接地址   jdbc:mysql://localhost:3306/数据库名
  private static final String USER="root";
  //用户名
  private static final String PASSWORD="root";
  //密码
  private static Connection coo;
  public static void main(String args[]) throws Exception{
      //第一步加载数据库驱动程序,此时不需要实例化,因为会由容器自己负责管理
      Class.forName(DBDRIVER);

      //链接数据库
      coo=DriverManager.getConnection(DBURL,USER,PASSWORD);
      String sql="SELECT ID,AGE FROM number where AGE IN(\"11013532\");";
      PreparedStatement pre=coo.prepareStatement(sql);
      ResultSet s=pre.executeQuery();
      if(s.next()){
          while (s.next()){
              System.out.println(s.getString(1)+s.getInt(2));
          }
      }
      else{
          System.out.println("该用户,尚未注册");
      }


      pre.close();
      coo.close();

  }
}
----
该用户,尚未注册


关于PreparedStatement接口,需要重点记住的是:

  1. PreparedStatement可以写参数化查询,比Statement能获得更好的性能。
  2. 对于PreparedStatement来说,数据库可以使用已经编译过及定义好的执行计划,这种预处理语句查询比普通的查询运行速度更快。
  3. PreparedStatement可以阻止常见的SQL注入式攻击。
  4. PreparedStatement可以写动态查询语句
  5. PreparedStatement与java.sql.Connection对象是关联的,一旦你关闭了connection,PreparedStatement也没法使用了。
  6. “?” 叫做占位符。
  7. PreparedStatement查询默认返回FORWARD_ONLY的ResultSet,你只能往一个方向移动结果集的游标。当然你还可以设定为其他类型的值如:”CONCUR_READ_ONLY”。
  8. 不支持预编译SQL查询的JDBC驱动,在调用connection.prepareStatement(sql)的时候,它不会把SQL查询语句发送给数据库做预处理,而是等到执行查询动作的时候(调用executeQuery()方法时)才把查询语句发送个数据库,这种情况和使用Statement是一样的。
  9. 占位符的索引位置从1开始而不是0,如果填入0会导致java.sql.SQLException invalid column index异常。所以如果PreparedStatement有两个占位符,那么第一个参数的索引时1,第二个参数的索引是2.

以上就是为什么要使用PreparedStatement的全部理由,不过你仍然可以使用Statement对象用来做做测试。但是在生产环境下你一定要考虑使用 PreparedStatement 。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • JDBC概述 在Java中,数据库存取技术可分为如下几类:JDBC直接访问数据库、JDO技术、第三方O/R工具,如...
    usopp阅读 3,533评论 3 75
  • JDBC概述 •什么是JDBC JDBC(Java DataBase Connectivity) 称为Java数据...
    草城篱梦阅读 453评论 0 6
  • 本人的环境为Myeclipse10、MySQL5.7.15 本文包括:简介JDBC编程步骤打通数据库程序详解—Dr...
    廖少少阅读 3,933评论 7 39
  • 我不能忘记那双眼睛二月白云恰到好处,扎起麻花髻在无叶无果,桂树枝头。你如常平静站在后方凌厉肆虐人心难抚没有心脏可以...
    Amaorent阿毛的空瓶子阅读 263评论 8 17
  • 若水晶鞋真的合脚,怎么会丢失呢? 若王子真的爱灰姑娘,又怎会拿鞋认人,而记不住灰姑娘的脸呢?
    落柒公子阅读 141评论 0 0