欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java通过JDBC连接数据库的三种方式!!!并对数据库实现增删改查

程序员文章站 2022-04-13 15:43:59
前言 java连接数据库完整流程为: 1,获得驱动(driver),数据库连接(url),用户名(username),密码(password)基本信息的三种方式。 2,通过获得的信息完成JDBC实现连接数据库。 注:连接前请导入jar包,例:连接mysql数据库需要导入mysql-connector ......

前言
java连接数据库完整流程为:
1,获得驱动(driver),数据库连接(url),用户名(username),密码(password)基本信息的三种方式。
2,通过获得的信息完成jdbc实现连接数据库。
注:连接前请导入jar包,例:连接mysql数据库需要导入mysql-connector-java-5.1.39-bin.jar包

连接数据库的三种方式
三种方式中二,三最为常用

一,直接获取数据库信息,并jdbc驱动连接

这里写代码片  public static connection connection() {
        //获得连接数据库连接
        connection conn=null;
        try {
        //初始化driver类,注册驱动
            class.forname("com.mysql.jdbc.driver");
            //连接数据库
            conn= drivermanager.getconnection("jdbc:mysql://localhost:3306/web", "root", "root");

        } catch (exception e) {
            e.printstacktrace();
        }
        return conn; 
    }

二,获得db.properties文件中的配置信息获得

注解: 
resourcebundle 类的作用就是读取资源属性文件(properties),根据.properties文件的名称信息(本地化信息),匹配当前系统的国别语言信息(也可以程序指定),然后获取相应的properties文件的内容。
public class jdbc_conn2 {
      private static string driver;
      private static string url;
      private static string username;
      private static string password;
      static {
          //通过resourcebundle获得db文件中的信息
          resourcebundle bundle = resourcebundle.getbundle("db");
          //通过key值获得db文件中的配置信息
          driver=bundle.getstring(driver);
          url=bundle.getstring(url);
          username=bundle.getstring(username);
          password=bundle.getstring(password);
      }

    public static connection mysqlconn() {
        //连接数据库
        connection conn=null;
            class.forname(driver);
            conn= drivermanager.getconnection(url, username, password);
            return conn; 
    }

三、通过io流获得db文件中配置信息

注解: 
*首先,调用对象的getclass()方法是获得对象当前的类类型,这部分数据存在方法区中,而后在类类型上调用getclassloader()方法是得到当前类型的类加载器,在java中所有的类都是通过加载器加载到虚拟机中的,
而且类加载器之间存在父子关系,就是子知道父,父不知道子,这样不同的子加载的类型之间是无法访问的(虽然它们都被放在方法区中),所以在这里通过当前类的加载器来加载资源也就是保证是和类类型同一个加载器加载的。 最后调用了类加载器的getresourceasstream()方法来加载文件资源*
public class jdbc_conn3 {
    private static string dirver;
    private static string url;
    private static string username;
    private static string password;
    static {
    //io流
        inputstream is=jdbc_conn3.class.getclassloader().getresourceasstream("db.properties");
        properties props=new properties();
        try {
            props.load(is);
        } catch (ioexception e) {
            // todo auto-generated catch block
            e.printstacktrace();
        }
        dirver=props.getproperty("driver");
        url=props.getproperty("url");
        username=props.getproperty("username");
        password=props.getproperty("password");
    }


    public static connection mysqlconn() {
        //1,获得连接数据库的驱动
        connection conn=null;
        class.forname(dirver);
        conn= drivermanager.getconnection(url, username, password);
        return conn; 
    }

连数据库后,使用完毕需要关闭连接

关闭数据库需要关闭以下资源:1,connection(连接).2,preparedstatement(预编译).3,result(结果集)

 public static void mysqlcolse(connection con,preparedstatement pstem,resultset rs) {

            try {
                if(con!=null) {
                con.close();
                }
                if(pstem!=null)
                {
                    pstem.close();
                }
                if(rs!=null) {
                    rs.close();
                }
            } catch (sqlexception e) {
                // todo auto-generated catch block
                e.printstacktrace();
            }


    }

完成以上步骤便是一个连接数据库的java模板了,以上连接方法与关闭方法存于一个java文件中即可完成。

增、删、改、查

前言

1   以下代码在完成连接数据库的基础之上完成,通过java实现对数据库的增删改查

一、查询功能
注:
connection中preparestatement()方法,提供占位符(?),占位符设置参数setxxx(index,value)。优点:改动参数时,不需改动sql,通过占位符修改。
resultset类,作为查询条件的返回集的作用

//先声明对象,优点在于方便下方任意代码块调用对象信息。
    connection con=null;
    preparedstatement pstm=null;
    resultset rs=null;

    @test
    public void testjv3()
    {
    //1,通过jdbc的模板连接上数据库
    con=jdbc_conn3.mysqlcon();
    //2,编写sql语句
    string sql="select * from user where uid=?";
    try {
    //3.预编译需要执行的sql
        pstm = con.preparestatement(sql);
        //preparestatement中占位符?,通过setxxx(index,values)来进行设置,index从1开始,
        pstm.setint(1, 1);
        //执行sql并返回查询结果
        resultset rs = pstm.executequery();
        if(rs.next())
        {
            string password=rs.getstring(3);
            string uname=rs.getstring(2);
            system.out.println(uname+":"+password);
        }else {
            system.out.println("没有结果");
        }
    } catch (sqlexception e) {
        // todo auto-generated catch block
        e.printstacktrace();
    }finally {
        jdbc_conn3.mysqlcolse(con, pstm, rs);
    }

    }

额外知识点:查询条件输出方式 
if():当只有一条结果时,可用if 
while():当有多条结果时,可用while

二、增,删,改

增删改,只需要改对应sql即可,以下代码为模板。
preparedstatement pstm=null;
        connection con=null;
        //1,实例化mydatasource
        combopooleddatasource mdsc= new combopooleddatasource();
        //2.从mydatasource的池中获得连接对象
        try {
            con= mdsc.getconnection();
        } catch (sqlexception e1) {
            // todo auto-generated catch block
            e1.printstacktrace();
        }
        //3.写sql
        string sql="insert into user values (null,?,?)";
        //4,预编译
        try {
            pstm= con.preparestatement(sql);
            pstm.setstring(1, "zj");
            pstm.setstring(2, "zj");
            int col=pstm.executeupdate();
            if(col>0) {
                system.out.println("添加成功:"+col+"条数");
            }else {
                system.out.println("添加失败");
            }
        } catch (sqlexception e) {
            // todo auto-generated catch block
            e.printstacktrace();
        }finally {
            jdbcutils_v3.release(con, pstm, null);
        }
    }