JDBC工具类。。。
package it.cast.jdbcutils; import java.io.InputStream; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.Properties; public class JdbcUtils { private static String JDriver=null; private static String connectDB=null; private static String username=null; private static String password=null; static { try { InputStream in =null; in= JdbcUtils.class.getClassLoader().getResourceAsStream("db.properties"); Properties prop=new Properties(); prop.load(in); JDriver=prop.getProperty("JDriver"); connectDB=prop.getProperty("connectDB"); username=prop.getProperty("username"); password=prop.getProperty("password"); Class.forName(JDriver); System.out.println("数据库连接成功"); } catch (Exception e) { throw new ExceptionInInitializerError("连接失败"); } } public static Connection getConnection() throws SQLException { return DriverManager.getConnection(connectDB,username,password); } public static void release (Connection conn,Statement st,ResultSet rs) { if(rs!=null) { try { rs.close(); } catch(Exception e) { e.printStackTrace(); } } if(st!=null) { try { st.close(); } catch(Exception e) { e.printStackTrace(); } } if(conn!=null) { try { conn.close(); } catch(Exception e) { e.printStackTrace(); } } System.out.println("数据库已经断开连接"); } //增删改方法。 public static void query(String sql,Object params []) throws SQLException { Connection conn =null; PreparedStatement st=null; ResultSet rs = null; conn = JdbcUtils.getConnection(); try { //获取数据连接 conn = JdbcUtils.getConnection(); //获取数据库对象并对SQL进行预编译 st =conn.prepareStatement(sql); //获取传进来的SQL,和传进来的参数。并进行赋值。 ;i<params.length;i++) { st.setObject(i+,params[i]); System.out.println(params[i]); } //执行 st.executeUpdate(); } finally { //释放 JdbcUtils.release(conn, st, rs); } } }
//实体类。
package in.cast.dao; public class data { private String date; private Integer num; public data (String date,Integer num) { this.date=date; this.num=num; } public String getDate() { return date; } public void setDate(String date) { this.date = date; } public int getNum() { return num; } public void setNum(Integer num) { this.num = num; } public String toString() { return date+" : "+num ; } }

  

测试:

package in.cast.dao;
import it.cast.jdbcutils.JdbcUtils;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class JDBC_TEST {
    public static void main (String [] args) throws Exception
    {

        JDBC_TEST T=new JDBC_TEST();

        HashMap<Integer,data> m=T.insert();

        DataSearch(m);

    }
    public static void DataSearch(HashMap<Integer, data> m) {
        Set<Map.Entry<Integer,data>> entryset=m.entrySet();

        Iterator <Map.Entry<Integer,data>>it=entryset.iterator();

        while(it.hasNext())
        {
            Map.Entry<Integer,data> mp=it.next();
            System.out.println(mp.getKey()+" : "+mp.getValue());

        }
    }
    public  HashMap<Integer,data> insert() throws Exception
    {
        HashMap<Integer,data> mp = new HashMap<Integer,data>();
        String s1;
        Integer s2;
        Connection conn=null;
        Statement st=null;
        ResultSet rs=null;
        Integer iCount=0;
        try
        {
            //获取数据库连接
            conn=JdbcUtils.getConnection();

            //返回一个statement,作用于发送SQL语句 。
            st = conn.createStatement();
            //SQL 语句
            String sql=" select * from tt ; " ;
            //返回一个数据集
            rs = st.executeQuery(sql) ;  //update
            //循环
            while(rs.next())
            {
                iCount++;
                s1=rs.getString("日期");//等同getObject(column_name)
                s2=Integer.parseInt(rs.getString("存入"));
                mp.put(iCount,new data(s1,s2));

            }
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
        finally
        {
             JdbcUtils.release(conn,st, rs);
        }

        return mp;
    }
    

配置文件:

JDriver=com.microsoft.sqlserver.jdbc.SQLServerDriver
connectDB=jdbc:sqlserver://127.0.0.1:1433;DatabaseName=test
username=sa
password=123

JDBC。

package in.cast.dao;
import java.sql.*;
public class test1{
    public static void main(String[] args) {
        //com.microsoft.sqlserver.jdbc.SQLServerDriver 2008
     String JDriver="com.microsoft.sqlserver.jdbc"; 2005 String connectDB="jdbc:sqlserver://127.0.0.1:1433;DatabaseName=test"; try{ Class.forName(JDriver);//通过反射加载驱动。 }catch(ClassNotFoundException e) { System.out.println("数据库连接异常"); //这里可以抛出一个自定义异常 } System.out.println("锟斤拷菘锟斤拷锟缴癸拷"); try{ String user="sa"; String password="123"; Connection con=DriverManager.getConnection(connectDB,user,password); Statement stmt=con.createStatement(); //建表 String query="create table TABLE1(ID NCHAR(2),NAME NCHAR(10))"; //提交语句 stmt.executeUpdate(query); String a1="INSERT INTO TABLE1 VALUES('1','a')"; String a2="INSERT INTO TABLE1 VALUES('2','b')"; String a3="INSERT INTO TABLE1 VALUES('3','c')"; stmt.executeUpdate(a1); stmt.executeUpdate(a2); stmt.executeUpdate(a3); ResultSet rs=stmt.executeQuery("SELECT * FROM TABLE1"); while(rs.next()){ System.out.println(rs.getString("ID")+"\t"+rs.getString("NAME")); } //从建表到插入数据到查询 。仅为熟悉语句。 stmt.close(); con.close(); }catch(SQLException e){ e.printStackTrace(); System.exit(0); } } }

java jdbc 封装。。的更多相关文章

  1. Java面向对象㈠ -- 封装

    Java的面向对象有三大特征:封装.继承.多态.这里主要对封装进行讲解. 封装可以理解为隐藏一个类的成员变量和成员函数,只对外提供需要提供的成员函数. Java的封装主要通过访问权限控制符:priva ...

  2. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  3. Java JDBC高级特性

    1.JDBC批处理 实际开发中需要向数据库发送多条SQL语句,这时,如果逐条执行SQL语句,效率会很低,因此可以使用JDBC提供的批处理机制.Statement和PreparedStatemen都实现 ...

  4. Java JDBC下执行SQL的不同方式、参数化预编译防御

    相关学习资料 http://zh.wikipedia.org/wiki/Java数据库连接 http://lavasoft.blog.51cto.com/62575/20588 http://blog ...

  5. Java JDBC批处理插入数据操作

    在此笔记里,我们将看到我们如何可以使用像Statement和PreparedStatement JDBC API来批量在任何数据库中插入数据.此外,我们将努力探索一些场景,如在内存不足时正常运行,以及 ...

  6. 体验Java的封装性

    package com.cnblogs.java; //体验Java的封装性 /* * 如下的人类年龄赋值-300岁,显然很不合理,这种直接对类的属性赋值,有时候虽然不合理但却会编译通过. * 所以我 ...

  7. JAVA中封装JSONUtils工具类及使用

    在JAVA中用json-lib-2.3-jdk15.jar包中提供了JSONObject和JSONArray基类,用于JSON的序列化和反序列化的操作.但是我们更习惯将其进一步封装,达到更好的重用. ...

  8. Java JDBC批处理插入数据操作(转)

    在此笔记里,我们将看到我们如何可以使用像Statement和PreparedStatement JDBC API来批量在任何数据库中插入数据.此外,我们将努力探索一些场景,如在内存不足时正常运行,以及 ...

  9. java jdbc使用配置文件连接数据库:

    java jdbc使用配置文件连接数据库: 创建后缀名为:.properties的文件,文件内容包括,数据库驱动.连接的数据库地址.用户名.密码…… 以Mysql为例创建config.properti ...

随机推荐

  1. 复利计算器(软件工程)及Junit测试———郭志豪

    计算:1.本金为100万,利率或者投资回报率为3%,投资年限为30年,那么,30年后所获得的利息收入:按复利计算公式来计算就是:1,000,000×(1+3%)^30 客户提出: 2.如果按照单利计算 ...

  2. Java之内存诊断

    Java 内存诊断比较容易, 需要: 1 获取heap dump 2 分析heap dump 1.1 获取dump之1 VM arguments: -XX:+HeapDumpOnOutOfMemory ...

  3. HDU2471_History of Languages

    有意思的题目,给出两个自动机,判断这个两个自动机是否是等价的? 两个自动机是等价的,那么他们可接受的字符串集合一定是完全一样的. 于是我们可以从(0,0)开始bfs,每次看看在两个自动机上走到的两个点 ...

  4. FMDB处理动态插入语句

    昨天做一个需求,参数的数量不确定,所以无法使用这个API: - (BOOL)executeUpdate:(NSString*)sql, ... 但是用 - (BOOL)executeUpdate:(N ...

  5. 控件(选择类): ListBox, RadioButton, CheckBox, ToggleSwitch

    1.ListBox 的示例Controls/SelectionControl/ListBoxDemo.xaml <Page x:Class="Windows10.Controls.Se ...

  6. ZOJ 3868 - Earthstone: Easy Version

    3868 - Earthstone: Easy Version Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%lld ...

  7. linux安装.run

    chmod +x ./framework-3.6.0-linux-full.runsudo ./framework-3.6.0-linux-full.run

  8. Tensorflow 上手——手写数字识别

    下面代码是Tensorflow入门教程中的代码,实现了一个softmax分类器. 第4行是将data文件夹下的mnist数据压缩包读取为tf使用的minibatch字典. 第6-11行定义了所用的变量 ...

  9. mssql 容易掉进的坑

    1.     重复 使用 into #tabel(不是在开头使用insert into ) 会报错   if  1=1 begin  select * into #tabel from product ...

  10. sgu 194 Reactor Cooling(有容量上下界的无源无汇可行流)

    [题目链接] http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=20757 [题意] 求有容量上下界的无源无汇可行流. [思路] ...