连接JDBC
 
    1)JDBC简介
        - JDBC就是Java中连接数据库方式
        - 我们可以通过JDBC来执行SQL语句。
 
    2)获取数据库连接
        - java.sql.Connection 数据库连接
        - 我们队数据库的一切操作都是从获取Connection开始
        - 获取数据库连接的四个参数:
            1.数据库的地址 url
                语法:jdbc:子协议:厂商内容
                MySQl的格式:jdbc:mysql://主机名:端口号/数据库名字
                例子:jdbc:mysql://localhost:3306/test
 
            2.用户名 user 连接数据库使用的用户名
            3.密码 password 数据库的密码
            4.数据库驱动全类名 driverClass
 
        - 基本步骤:
            1.导入数据库驱动的jar包
                mysql-connector-java-5.1.37-bin.jar
            2.准备四个参数
                - url
                - user
                - password
                - driverClass
            3.加载数据库驱动
                Class.forName(driverClass)
            4.通过DriverManager来获取数据库连接   
                static Connection getConnection(String url, String user, String password)           
 
        - 核心类:
            - java.sql.DriverManager
                - 数据库驱动的管理器,负责加载数据库的驱动获取数据库连接
                - static Connection getConnection(String url, String user, String password) 
                    - getConnection方法用来通过url地址,用户名,密码等参数来获取数据库连接的
 
            - java.sql.Connection
                - 数据库连接
                - Statement createStatement() 
                    - 创建一个Statement对象,通过Statement对象来执行SQL语句
 
            - java.sql.Statement
                - SQL语句的执行器
                    - boolean execute(String sql) 
                        - 执行一条SQL语句,并返回一个布尔值,执行成功返回true,执行失败返回false。用的不多
                    - ResultSet executeQuery(String sql) 
                        - 执行查询的SQL语句,并返回一个结果集
                    - int executeUpdate(String sql) 
                        - 执行修改数据的SQL语句(增删改),并返回受影响的行数
 
            - java.sql.ResultSet
                - 查询到的数据的结果集,我们通过JDBC查询数据库获得的数据,都封装在ResultSet中
                - boolean next() 
                    - 控制光标向下移动一行,如果光标当前位置是afterLast则返回false,告诉你没数据了,就别读了。
                        如果光标移动以后,没有在afterLast则返回true,可以读取数据。
 
                - 在ResultSet有很多getXxx(int),比如getString(),getInt(),getByte()。
                    通过这些方法可以读取当前行的数据,它们需要一个int值作为参数,
                        int指的是读取数据的列数。
                    列数是从1开始的。
 
                - 在ResultSet中还有很多getXxx(String),它和上边的方法的作用一致,
                    只不过它们需要的都是String类型的参数,参数代表的是当前的列名,
                        比如:我们要获取id的值
                            getInt("id")
                        要获取name的值
                            getString("name")
                    注意:如果查询的SQL使用了别名,则列名以别名为准。
 
    3)数据的增删改
        //创建一个SQL执行器
        Statement stat = conn.createStatement();
 
        //创建一个SQL语句
        String sql = "INSERT INTO t_stu(`name` , age) VALUES('沙僧',28)";
 
        //执行SQL语句
        //executeUpdate用来执行一条修改SQL的语句
 
        //它需要一个String类型sql作为参数,并会返回一个int型的值,该值表示SQL语句执行以后影响到的行数
        int count = stat.executeUpdate(sql);
 
    4)数据的查询
        //创建Statement对象
        Statement stmt = conn.createStatement();
        //创建一个SQL语句
        String sql = "SELECT id, name sname, age FROM t_stu WHERE id=2";
        //执行查询
        ResultSet rs = stmt.executeQuery(sql);
        //控制光标下移一行
        //如果当前行有数据,则读取
        if(rs.next()){
 
            //获取id,name,age
            int id = rs.getInt("id");
            String name = rs.getString("sname");
            int age = rs.getInt("age");
 
            System.out.println(id+"--"+name+"--"+age);
        }
 
        > 查询操作和修改的主要不同的是,查询使用executeQuery(),
            它会返回ResultSet结果集,我们需要对结果集进行读取。
 
        > 当我们只需要读取一个数据时,用if。
            当需要读取全部数据时,用while
 
        > 代码的规范:
            - Connection、Statement、ResultSet,这些资源都是需要和数据建立连接的
                这些资源我们并不是总需要使用,当我们不适用这些资源,需要将这些资源关闭。
            - 关闭资源顺序:
                从后往前关:
                    先关 ResultSet
                    在关 Statement
                    最后关 Connection
            - 示例代码:
                //定义三个变量
                Connection conn = null;
                Statement stmt = null;
                ResultSet rs = null;
 
                try{
 
                }catch(Exception e){
                    e.printStackTrace();
                }finally{
 
                    if(rs!=null){
                        //关闭ResulSet
                        try {
                            rs.close();
                        } catch (SQLException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                    }
 
                    if(stmt != null){
                        try {
                            stmt.close();
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }
 
                    if(conn != null){
                        try {
                            conn.close();
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }
 
                }
 
DAO(Data Access Object) 数据访问对象:
    在Java中使用DAO类,来去和数据库交互,而其他类不再需要编写JDBC相关的代码,
        而是直接调用DAO。
    在实际上开发中,我们所有的JDBC相关的代码都应该写在DAO中,
        java.sql这个包下的内容不应该出现在DAO以外的地方
 
    t_user
 
        CREATE TABLE t_user(
            id INT PRIMARY KEY AUTO_INCREMENT,
            username VARCHAR(100),
            `password` VARCHAR(100),
            email VARCHAR(100),
            nickname VARCHAR(50)
        )
 
    创建UserDao(负责User对象和数据库相关的操作)   
 
        User getUserByUsername(String username) --> 根据用户查找用户
 
        int saveUser(User user); --> 将用户对象插入进数据库
 
        User getUserByUsernameAndPassword(String username , String password) --> 根据用户名和密码查找用户
 
    登录:
        登录实际上就是这么一条SQL语句:
            SELECT * FROM t_user WHERE username='' AND password=''
 

JDBC数据库连接JAVA和一些基本语句的更多相关文章

  1. JDBC 数据库连接 Java操作数据库 jdbc快速入门

    JDBC基本概念 Java DataBase Connectivity 数据库连接 java操作数据库 本质上(sun公司的程序员)定义的一套操作关系型数据库的规则 既接口  更新内容之前 代码 pa ...

  2. Java jdbc数据库连接池总结!(转)

    1. 引言 近年来,随着Internet/Intranet建网技术的飞速发展和在世界范围内的迅速普及,计算机 应用程序已从传统的桌面应用转到Web应用.基于B/S(Browser/Server)架构的 ...

  3. JDBC(Java Data Base Connectivity,java数据库连接)

    JDBC概述 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言 ...

  4. 【学习笔记】JDBC数据库连接技术(Java Database Connectivity)

    一.JDBC简介 Java是通过JDBC技术实现对各种数据库的访问的,JDBC是Java数据库连接技术的简称.它可以把数据持久保存,是一种持久化机制. 1.持久化 持久化就是将程序中的数据在瞬时状态和 ...

  5. Java自学-JDBC 数据库连接池

    数据库连接池 与线程池类似的,数据库也有一个数据库连接池. 不过他们的实现思路是不一样的. 本章节讲解了自定义数据库连接池类:ConnectionPool,虽然不是很完善和健壮,但是足以帮助大家理解C ...

  6. JDBC:(java database Connection) java数据库连接。

    JDBC 指 Java 数据库连接,是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库. JDBC连接步骤: 1.先导入jar包,把jar放入到工程下并 ...

  7. JAVA之JDBC数据库连接池总结篇

    JDBC数据库连接池 一.JDBC数据库连接池的必要性 二.数据库连接池技术 三.多种开源的数据库连接池 3.1 C3P0数据库连接池 3.2 DBCP数据库连接池 3.3 Druid(德鲁伊)数据库 ...

  8. JAVA基础知识之JDBC——JDBC数据库连接池

    JDBC数据库连接池 数据库的连接和关闭是很耗费资源的操作,前面介绍的DriverManager方式获取的数据库连接,一个Connection对象就对应了一个物理数据库连接,每次操作都要打开一个连接, ...

  9. JDBC数据库连接池原理

    JDBC是java数据库连接的简称.它是一种用于实行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用java语言编写的类和接口组成.其相关的API都在java.sql.*包下 ...

随机推荐

  1. VB6之GIF分解

    原文链接:http://hi.baidu.com/coo_boi/item/1264a64172fe8dec1f19bc08 还是找了个C++的翻译下,原文链接:http://www.360doc.c ...

  2. HDOJ 2209 贪心

    翻纸牌游戏 Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  3. Mac之OS系统下搭建JavaEE环境 <四> 之IntelliJ IDEA 的内存优化

    1.代开IntelliJ IDEA 的显示内容 2. 打开idea.vmoptions文件 路径为Contens——bin——idea.vmoptions 修改之前会复制一份备份原配置 原配置 修改后 ...

  4. 【.net 深呼吸】监听剪贴板更新(针对Vista之后系统)

    针对 XP 及以前的监视剪贴板更改的方法就不讲了,因为 XP 已严重过时.本篇老周介绍的方法面向 Vista 以上的系统. 在托管应用程序中监听剪贴板更新行为必须用到 Win 32 API ,具体做法 ...

  5. 提交到APPStore出现ERROR ITMS-90474

    解决的方案是:在工程的targets--->General----->Develoment Info ------->Status BarStyle

  6. dubbo&hsf&spring-cloud简单介绍

    Dubbo: 简介:Dubbo是一个分布式服务框架,以及SOA治理方案.其功能主要包括:高性能NIO通讯及多协议集成,服务动态寻址与路由,软负载均衡与容错,依赖分析与降级等. 底部NIO基于netty ...

  7. Java 简单的 socket 编程入门实战

    这个是给女朋友写的:) 首先需要知道我们每个电脑都可以成为server(服务器) 和 client(客户端) 我们需要使用java来实现客户端与服务器的数据传输 先帖上代码 注意这里两张代码处于两个j ...

  8. 文科生细谈学习Linux系统的重要性

    首先大概介绍下自己,我学的是公共事业管理方面的专业,可以说是面向纯理论,社区管理社会管理的专业,但是从大二开始,对网络及服务器运维方面产生浓厚兴趣,并不断在网上找相关资料. 在这期间经历过很多,单说桌 ...

  9. nodeJS之域名DNS

    前面的话 本文将详细介绍域名解析模块DNS 工作原理 打开浏览器,在上方地址栏输入网址的那一刻,这个回车按了之后,发生了很多事情.首先,计算机只懂0和1,也就是说人类的字母网址计算机是不懂的,它只认识 ...

  10. JPA常用注解

    JPA全称Java Persistence API.JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中.        JPA由EJB 3.0软件专家 ...