JDBC数据库连接学习
    用jdbc连接数据库
    1.加载驱动
        Class.forName("");
        用注册的方式会使内存中存在两个对象,而用上边的方法内存中仅存在一个驱动不需要依赖具体的API程序灵活性更高
    2.得到连接
        Connection conn = DriverManager();
    3.创建sql对象
        PreparedStatement
        CallableStatement
        Statement statement = conn.createStatement();
    4.通过statement向数据库发送sql指令
        statement.executeUpdate(sql); //执行 dml(update insert delete)
        statement.executeQuery(sql); //执行
    5.关闭资源(先开后闭,后开先闭)
    
    Connection 他代表数据库的连接。客户端与数据库所有交互都通过connection对象完成。
        createStatement();    创建数据库发送sql的statement对象
        prepareStatement(sql);    创建向数据库发送预编译sql的PerpareStatement对象。可以防止sql注入
        prepare(sql); 创建执行存储过程中的callableStatement对象
        
        什么时候需要吧setAutoCommit设为false,setAutoCommit(boolean autoCommit);    设置事务是否自动提交,把一组dml语句一起提交时,使用事务管理,设置成false(相当于做成原子性吧,我这样理解);
        
        commit();    
        rollback();
        ResultSet对象调用next() 方法最后一个返回false;注意是false不是null
        Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE);
        ResultSet中的静态常量
                    CLOSE_CURSORS_AT_COMMIT        该常量指示提交当前事务时,具有此可保存性的打开的 ResultSet 对象将被关闭。
                    CONCUR_READ_ONLY                     该常量指示不可以更新的 ResultSet 对象的并发模式。
                    CONCUR_UPDATABLE                     该常量指示可以更新的 ResultSet 对象的并发模式。
                    FETCH_FORWARD                       该常量指示将按正向(即从第一个到最后一个)处理结果集中的行。
                    FETCH_REVERSE
                    FETCH_UNKNOWN
                    HOLD_CURSORS_OVER_COMMIT
                    TYPE_FORWARD_ONLY
                    TYPE_SCROLL_INSENSITIVE     该常量指示可滚动但通常不受 ResultSet 底层数据更改影响的 ResultSet 对象的类型。
                    TYPE_SCROLL_SENSITIVE         该常量指示可滚动并且通常受 ResultSet 底层数据更改影响的 ResultSet 对象的类型。
        ResultSet rs = stmt.executeQuery("SELECT a, b FROM table");
        
        ResultSet 在默认情况下,我们的rs结果集,只能向前移动,这样rs结果集就不能复用。
        我们可以这样做
            statement = ct.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
            
        rs.beforeFirst(); //我们希望重新使用结果集,
        rs.next();                //移动到下一行
        rs.Previous();        //移动到前一行
        rs.absolute(row); //移动到指定行
        rs.afterLast();        //移动到resultSet的最后面
        
        !!提问如果数据库中列的类型是varchar2,获取该列的数据调用什么方?Int类型呢?bigInt类型呢?Boolean类型呢?
        MySQL数据库JDBC对应类型数据表
        
        MySQL的连接并发,最大连接量13000
        
        即时关闭资源,一个资源不关也会出现问题。
        Connection连接尽可能晚连接,尽可能早释放,如果不能处理好Connection就极可能出现宕机。
        关闭资源的代码一定要放在finally
        
        SqlHelper类的编写                        
            1、访问数据库很平凡、有并发量时,不要把Connection设定成static
            2、加载驱动就需要一次

16-1-27---JDBC复习(01)的更多相关文章

  1. JDBC复习

    -----------------------------------------JDBC复习----------------------------------------- 1.JDBC (Jav ...

  2. Bone Collector(复习01背包)

    传送门 题目大意:01背包裸题. 复习01背包: 题目 有N件物品和一个容量为V的背包.第i件物品的费用是c[i],价值是w[i].求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量,且价值总 ...

  3. JDBC复习2

    前面复习了一些基础知识以及如何抽取一些常用的代码,接下来就结合junit4做一个增删改查的小demo 重点是这么几个步骤:1.创建连接 2.编写sql语句 3.编写sql语句的载体 4.如果是Prep ...

  4. mybatis复习01

    1.mybatis的历史: mybatis是apache的一个开源项目,2010被google收购,转移到google code. mybatis是一个优秀的持久层框架,对jdbc操作进行了封装,是操 ...

  5. JDBC 复习2 存取mysql 大数据

    大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据 mysql的大数据分为2种 blob 和 text ,没有cl ...

  6. JDBC 复习1 DBUtil

    package dbex; import java.io.Closeable; import java.io.IOException; import java.io.InputStream; impo ...

  7. java数据结构复习01

    1.数组 package javaDataStruct.array01; public class MyArray { private int[] arr; // 表示有效数据的长度 private ...

  8. nodejs复习01

    console 格式化 console.log("%s:%s", "a", "b") //字符串 console.log("%d. ...

  9. JDBC复习1

    1.什么是JDBC JDBC是java数据库连接技术的简称(Java DataBase Connectivity) jdbc是接口,jdbc驱动才是接口的实现,负责连接各种不同的数据库.jdbc的AP ...

  10. codevs 2837 考前复习——01背包

     时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description Aiden马上要考试了,可他还没怎么复习,于是他 ...

随机推荐

  1. windows XP上实现python2.7.5和python3.4.3共存

    windows XP上实现python2.7.5和python3.4.3共存过程记录: 1. 首先安装python2.7.5和python3.4.3,两个版本安装顺序不分前后; 2. 检查系统环境变量 ...

  2. Linux中检索文件

    1 , Use locate command It is a fast way to find the files location, but if a file just created ,it w ...

  3. Network

    App Icon: http://www.easyicon.net/

  4. Linux下实现秒级的crontab定时任务

    crontab的格式如下 * * * * * command 分 时 日 月 周 命令 第1列表示分钟1-59 每分钟用*或者 */1表示 第2列表示小时1-23(0表示0点) 第3列表示日期1-31 ...

  5. CSS3动画第二式--组合动画

    接第一式之后的进阶招式,加入一些组合动画,剧情.动画啥的都是随意瞎想的,纯粹是为了熟悉2D.3D和过渡等css3代码写法.效果见下图: 代码如下(有点长,折叠一下): <!DOCTYPE htm ...

  6. python+paramiko库+svn写的自动化部署脚本

    第一篇博文 直接开门见山的说了. 这是件什么事?:每次部署都是复制本地的文件粘贴到服务器端,因为路径复杂,所以费时且手工容易出漏洞. 一直在想有什么办法可以解决这种,因为以前在微软的一个牛人同事做过一 ...

  7. HTTP返回码中301与302的区别 (转载)

    一.官方说法 301,302 都是HTTP状态的编码,都代表着某个URL发生了转移,不同之处在于:  301 redirect: 301 代表永久性转移(Permanently Moved). 302 ...

  8. try catch里面try catch嵌套

    try catch里能否内嵌try catch?答案是肯定的.但是等内层try catch出异常之后是个什么执行顺序呢?看下面代码 static void Main(string[] args) { ...

  9. cat命令

    [cat]          合并文件和打印到标准输出 命令格式: cat [OPTION]... [FILE]... 命令功能: 拼接文件或者做标准输入输出 命令格式: cat [OPTION].. ...

  10. CentOS系统中基于Apache+php+mysql的许愿墙网站的搭建

    1.首先,我们需要两台虚拟机(CentOS7,Linux文本). 2.给两台虚拟机配置网络环境分别为桥接模式 CentOS7 ip为192.168.100.139.24,linux文本ip为192.1 ...