/* 01 连接池版本的 数据库 连接管理工具,适合于并发场合 */

package cn.tedu.jdbc.day02;

import java.io.InputStream;

import java.sql.Connection;

/*接口 Connection ,Connection 对象的数据库能够提供描述其表、所支持的 SQL 语法、存储过程、此连接功能等等的信息。此信息是使用 getMetaData 方法获得的。 */

import java.util.Properties;

public class DBUtilsDay02 {
  private static String driver;
  private static String url;
  private static String username;
  private static String password;
  private static String initSize;
  private static String maxActive;
  private static BasicDataSource ds;

  //静态代码块
  static{
      ds = new BasicDataSource();
      Properties cfg = new Properties();
      try{
        //db.properties 是src/main/resources 下文件
        // 这里的代码书写是模式,就这样谢
        InputStream inputStream = DBUtilsDay02.class.getClassLoader().getResourceAsStream("db.properties");
        cfg.load(inputStream);
        //初始化参数
        driver = cfg.getProperty("jdbc.driver");
        url = cfg.getProperty("jdbc.url");
        username = cfg.getProperty("jdbc.username");
        password = cfg.getProperty("jdbc.password");
        //initSize = Integer.parseInt(cfg.getProperty("initSize"));
        initSize = cfg.getProperty("initSize");
        //maxActive = Integer.parseInt(cfg.getProperty("maxActive"));
        maxActive = cfg.getProperty("maxActive");

        inputStream.close();

        //初始化连接池
        ds.setDriverClassName(driver);
        ds.setUrl(url);
        ds.setUsername(username);
        ds.setPassword(password);
        ds.setInitialSize(initSize);
        ds.setMaxAxtive(maxActive);
      }catch(Exception e){

        e.printStackTrace();  //e.printStackTrace( )是打印异常栈信息

        throw new RuntimeException(e)  //throw new RuntimeException(e)是把异常包在一个运行时异常中抛出。
        }
    }

public static Connection getConnection(){
    try{
        //getConnection() 从连接池中获取重用的链接,如果连接池满了,则等待,如果有链接归还,则获取重用的链接;
        Connection conn = ds.getConnection();
        return conn;
     }catch(Exception e){
        e.printStackTrace();
        throw new RuntimeException(e);
        }
     }

public static void close(Connection conn){
    if(conn!=null){
      try{
          //将用过的链接归还到链接池
          conn.close();
      }catch(Exception e){
          e.printStackTrace();
          }
        }
    }
}

/* 02 演示预编译的SQL执行计划 */

package cn.tedu.jdbc.day02;
import java.sql.Connection;
import java.sql.PreparedStatement;
import javax.print.attribute.standard.PageRanges;
import cd.tedu.jdbc.DbUtils;

public class DemoDay04 {
    public static void main(String[] args) {
    Connection conn = null;
    try {
        /*创建连接*/
        conn = DBUtilsDay02.getConnection();  /*getConnection方法在连接池中没有连接可以使用时候,会阻塞等待*/
        String sql="insert into robin_demo"+"(id,nema) values(?,?)";

        /* String sql = "UPDATE biaom "+"SET name= ?"+"WHERE id=?" */

        /*将sql发送到数据库,创建执行计划*/
        //返回值ps就代表执行计划
        PreparedStatement ps = conn.prepareStatement(sql);
        //替换执行计划中的参数,2个参数,按照序号发送参数
        ps.setInt(1,8);
        ps.setString(2,"sjkdo");

        //执行“执行计划”
        int n = ps.executeUpdate();
        System.out.println(n);
      } catch (Exception e) {
          // TODO: handle exception
          e.printStackTrace();
        }finally {
            DBUtilsDay02.class(conn);
          }

      }
  }

/* 03 使用执行计划执行更新语句 */

package cn.tedu.jdbc.day02;

import java.sql.Connection;

import java.sql.PreparedStatement;

public class DemoDay05 {

    public static void main(String[] args) {
    Connection conn = null;
    try {
        conn =DBUtilsDay02.getConnection();
        String sql = "UPDATE biaom "+"SET name= ?"+"WHERE id=?";
        PreparedStatement ps = conn.prepareStatement(sql);
        ps.setString(1, "laowang");// 这里德 1 指参数的位置,name
        ps.setInt(2, 100);
        int n = ps.executeUpdate();
        System.out.println(n);

      } catch (Exception e) {
        // TODO: handle exception
        e.printStackTrace();
      }finally {
          DBUtilsDay02.class();
          }
   }
}

/* 04 利用ps实现查询功能 */

package cn.tedu.jdbc.day02;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

public class DemoDay06 {

  public static void main(String[] args) {

      Connection conn = null;
      try {
          conn = DBUtilsDay02.getConnection();/*getConnection方法在连接池中没有连接可以使用时候,会阻塞等待*/
          /*执行sql*/
          String sql="select *"+"from cust_info_alon"+"where name like ?";
          PreparedStatement ps = conn.prepareStatement(sql);
          ps.setString(1, "%w%");
          /*执行参数*/
          ResultSet rs = ps.executeQuery();


          while(rs.next()){
          //getInt(可以放列的序号),利用序号获取值
          int id=rs.getInt(1);
          String name=rs.getString(2);
          System.out.println(id+","+name);
              }
        } catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }finally {
            DBUtilsDay02.class();
        }
      }
   }

/*  05 sql注入演示
* create table robin_user(
* id number(6), name varchar2(100),pwd varchar2(100)
* );

* insert into robin_user(id,name,pwd) valuse(1,'tom','123');
* */

package cn.tedu.jdbc.day02;

import java.sql.Statement;

import java.util.Scanner;

import java.sql.Connection;

import java.sql.ResultSet;

public class DemoDay07 {

    public static void main(String[] args) {

        //获取用户输入
        Scanner in = new Scanner(System.in);
        //输入用户名
        System.out.println("用户名");
        String name = in.nextLine();

        //输入密码
        System.out.println("密码");
        String pwd = in.nextLine();

        //检查登录情况
        boolean pass = login(name, pwd);

        if(pass){
            System.out.println("欢迎你!"+name);
        }else{
            System.out.println("用户密码出问题了!");
          }
      }

    //检查用户是否能够登录
    public static boolean login(String name,String pwd) {
        /* \' 代表一个单引号(撇号)字符 */
        String sql="select count(*) as c"+"from cust_info_alon"+"where neam=\'"+name+"\'"+"and pwd=\'"+pwd+"\'";
        System.out.println(sql);

        Connection conn = null;
        try {
            conn = DBUtilsDay02.getConnection();
            Statement st =conn.createStatement();
            ResultSet rs = st.executeQuery(sql);

            while(rs.next()){
                int n = rs.getInt("n");
                return n >=1;
                }

          } catch (Exception e) {
              // TODO: handle exception
              e.printStackTrace();
          }finally {
              DBUtilsDay02.close(conn);
          }
          return false;
        }
    }

[02-02 ]Java数据库链接范列的更多相关文章

  1. Java JDBC 数据库链接小结随笔

    Java JDBC 数据库链接小结随笔 一.链接数据库的步骤 二.关于Statement  和  PrepareStatement 两者区别 用法 三.关于 ResultSet 的一些小结 四.自定义 ...

  2. [原创] 【2014.12.02更新网盘链接】基于EasySysprep4.1的 Windows 7 x86/x64 『视频』封装

    [原创] [2014.12.02更新网盘链接]基于EasySysprep4.1的 Windows 7 x86/x64 『视频』封装 joinlidong 发表于 2014-11-29 14:25:50 ...

  3. 【全网最全的博客美化系列教程】02.添加QQ交谈链接

    全网最全的博客美化系列教程相关文章目录 [全网最全的博客美化系列教程]01.添加Github项目链接 [全网最全的博客美化系列教程]02.添加QQ交谈链接 [全网最全的博客美化系列教程]03.给博客添 ...

  4. 关于在Java中链接SQLServer数据库中失败的原因分析

    首先声明:笔者是Java的初学者,并且一值是走在自学的道路上,长久以来只有“度娘”相伴.(加入了各种Java学习群,基本没有热心帮人解决问题的.可以理解-_-!!!)大神级的人物就不必看拙文了,没有什 ...

  5. Java JDBC链接Oracle数据库

    package com.test.test; import java.io.FileInputStream;import java.io.FileNotFoundException;import ja ...

  6. java jdbc 链接mysq 测试l 云服务器 和云数据库 mysql DB

    话不多说直接上效果图 下面给出参考代码: package com.humi.db; import java.sql.Connection; import java.sql.DriverManager; ...

  7. MySQL学习02(操作数据库)

    操作数据库 结构化查询语句分类 名称 解释 命令 DDL(数据库定义语言) 定义和管理数据对象,例如数据库和数据表 create.drop.alter DML(数据操作语言) 用于操作数据库对象中所包 ...

  8. Java数据库操作(MySQL与SQLserver)

    在java编程开发中,数据库的开发是重头戏. MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品: SQL Server是由Microsoft开发 ...

  9. EntityFramework 多数据库链接,MySql,SqlServer,Oracel等

    环境:EntityFramework5.0,MySql5.6,MSSQL2012 EF是强大的ORM工具,真正意义上的多数据库链接指的是不同类型的数据库,以及同种类型的数据库多个库,EF很好的支持这一 ...

随机推荐

  1. C# - LINQ 表达式树

    表达式树(Expression Tree) 表达式树是不可执行的代码,它只是用于表示一种树状的数据结构,树上的每一个节点都表示为某种表达式类型,大概有25种表达式类型,它们都派生自Expression ...

  2. Django之Model

    一.字段 常用字段: AutoField:int自增列,必须填入参数 primary_key=True.当model中如果没有自增列,则自动会创建一个列名为id的列. IntergerField:一个 ...

  3. TCP-IP详解笔记4

    TCP-IP详解笔记4 系统配置: DHCP和自动配置 每台主机和路由器需要一定的配置信息,配置信息用于为系统指定本地名称,及为接口指定标识符(如IP地址). 提供或使用各种网络服务,域名系统(DNS ...

  4. C++设计模式——迭代器模式

    前言 最近非常感伤,总是怀念大学的日子,做梦的时候也常常梦到.梦到大学在电脑前傻傻的敲着键盘,写着代码,对付着数据结构与算法的作业:建立一个链表,遍历链表,打印链表.现在把那个时候声明的链表的头文件拿 ...

  5. 51nod--1185 威佐夫游戏 V2 (博弈, 乘法模拟)

    题目: 1185 威佐夫游戏 V2 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 有2堆石子.A B两个人轮流拿,A先拿.每次可以从一堆中取任意个或从2堆中 ...

  6. LightOJ 1349 Aladdin and the Optimal Invitation(中位数)

    题目链接:https://vjudge.net/contest/28079#problem/N 题目大意:给一个mxn的平面,有q个位置,每个位置坐标为(u,v)有w人,求一个点在平面内使得所有人都到 ...

  7. Apache服务器中设置端口映射和反向代理的方法

    在/etc/httpd/conf路径下的httpd.conf文件###new add for webui.cong###Include "E:/local/Wamp/bin/apache/A ...

  8. linux基础一篇就够了

    Linux学习笔记 粗略笔记第一版,全文约2000行50000字 1. 时间和日历 date:查看当前时间 cal:查看当月日历 cal 2018:查看年日历 cal 10 2018:指定某年某月日历 ...

  9. Felx布局基础教程

    网页布局即layout是css的一个重点应用. 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性.它对于那些特殊布局非常不方便,比如,垂直居中 ...

  10. python selenium Chrome模拟手机浏览器

    在做移动端页面测试时可以利用Chrome mobile emulation 辅助完成页面的适配问题,但是目前手机市场上的型号居多我们也没有办法通过人工的模式一一的去适配,所以这里考虑到通过自动化的模式 ...