java数据库管理之jdbc

JDBC的开发步骤

public class Main {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
    // write your code here
        
        //1.加载mysql数据库驱动
        Class.forName("com.mysql.jdbc.Driver");

        //2.获得数据库连接对象
        String url = "jdbc:mysql://localhost:3306/mybase";//要连接的数据库服务器的基本信息,包括ip,端口,数据库名
        String username = "root";
        String password = "root";
        Connection connection = DriverManager.getConnection(url,username,password);
        //System.out.println(connection);

        //3.创建数据库执行对象,相当于navicat里的查询窗口
        Statement statement = connection.createStatement();

        //4.执行查询语句
        ResultSet resultSet = statement.executeQuery("select * from sort");
        while(resultSet.next())//等同于while(resultSet.next() = true)
        {
            //System.out.println(resultSet.getString("sname"));//resultSet.getX("Y")Y属于什么类型,X就是什么类型
            String strName = resultSet.getString("sname");
            Double dPrice = resultSet.getDouble("sprice");
            System.out.println(strName + "  " + dPrice);
        }

        //插入一条记录
        //int rows = statement.executeUpdate("insert into sort(sname,sprice,sdesc) values('汽车用品',50000,'疯狂涨价')");

        //删除一条记录
        //int delRows = statement.executeUpdate("delete from sort where sid = 1");

        //5.关闭数据库连接
        resultSet.close();//需要先关闭
        statement.close();
        connection.close();
    }
}

注入攻击(不用这个代码编程序)

public class LoginDemo {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //1.加载mysql数据库驱动
        Class.forName("com.mysql.jdbc.Driver");
        //2.获得数据库连接对象
        String url = "jdbc:mysql://localhost:3306/mybase";//要连接的数据库服务器的基本信息,包括ip,端口,数据库名
        String username = "root";
        String password = "root";
        Connection connection = DriverManager.getConnection(url,username,password);

        //3.创建数据库执行对象,相当于navicat里的查询窗口
        Statement statement = connection.createStatement();
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入用户名:");
        String uName = scanner.nextLine();
        System.out.println("请输入密码:");
        String pwd = scanner.nextLine();
        String strSql = "select * from users where username = '"+uName+"' and password = '"+pwd+"' ";

        //4.处理登录
        ResultSet resultSet = statement.executeQuery(strSql);
        if (resultSet.next() == false)
        {
            System.out.println("登录失败");
        }
        else
        {
            System.out.println("登录成功");
        }

        //5.关闭连接
        resultSet.close();
        statement.close();
        connection.close();

    }
}

(用这个代码编程序)

public class LoginDemo {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //1.加载mysql数据库驱动
        Class.forName("com.mysql.jdbc.Driver");
        //2.获得数据库连接对象
        String url = "jdbc:mysql://localhost:3306/mybase";//要连接的数据库服务器的基本信息,包括ip,端口,数据库名
        String username = "root";
        String password = "root";
        Connection connection = DriverManager.getConnection(url,username,password);

        //3.创建数据库执行对象,相当于navicat里的查询窗口
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入用户名:");
        String uName = scanner.nextLine();
        System.out.println("请输入密码:");
        String pwd = scanner.nextLine();
        PreparedStatement preparedStatement = connection.prepareStatement("select * from users where username = ? and password = ?");
        preparedStatement.setString(1,uName);
        preparedStatement.setString(2,pwd);

        //4.处理登录
        ResultSet resultSet = preparedStatement.executeQuery();
        if (resultSet.next() == false)
        {
            System.out.println("登录失败");
        }
        else
        {
            System.out.println("登录成功");
        }

        //5.关闭连接
        resultSet.close();
        preparedStatement.close();
        connection.close();

    }
}

更新操作

public class UpdateDemo {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //1.加载mysql数据库驱动
        Class.forName("com.mysql.jdbc.Driver");
        //2.获得数据库连接对象
        String url = "jdbc:mysql://localhost:3306/mybase";//要连接的数据库服务器的基本信息,包括ip,端口,数据库名
        String username = "root";
        String password = "root";
        Connection connection = DriverManager.getConnection(url,username,password);
        //3.创建数据库执行对象,相当于navicat里的查询窗口
        PreparedStatement preparedStatement = connection.prepareStatement("update sort set sname = ? ,sprice = ?, sdesc=? where sid = ? ");
        preparedStatement.setString(1,"口红");
        preparedStatement.setDouble(2,11000.1);
        preparedStatement.setString(3,"限量版口红");
        preparedStatement.setInt(4,4);
        //4.处理(执行)
        int rows = preparedStatement.executeUpdate();
        //5.关闭数据库连接
        preparedStatement.close();
        connection.close();
    }
}

JDBC的工具类(代码固定)

public class JDBCUtils {
     private static Connection conn = null;
        private static String url;
        private static String username;
        private static String password;
        static {
            InputStream inputStream = JDBCUtils.class.getClassLoader().getResourceAsStream("db.properties");
            Properties properties = new Properties();
            try {
                properties.load(inputStream);
            } catch (IOException e) {
                e.printStackTrace();
            }
            //1.加载mysql数据库驱动
                try {
                    Class.forName(properties.getProperty("driver"));
                } catch (ClassNotFoundException e) {
                    e.printStackTrace();
                }

            //2.获得数据库连接对象
             url = properties.getProperty("url");
            //要连接的数据库服务器的基本信息,包括(ip,端口,数据库名)
             username = properties.getProperty("username");
             password = properties.getProperty("password");


        }

        private JDBCUtils(){}


        public static Connection getConnection()
        {
            try {
                conn = DriverManager.getConnection(url,username,password);
            } catch (SQLException e) {
                e.printStackTrace();
            }
            return conn;
        }

        public static void close(Statement statement, Connection connection)
        {
            if(statement != null)
            {
                try {
                    statement.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

            if(connection != null)
            {
                try {
                    connection.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

        }

        public static void close(ResultSet resultSet, Statement statement, Connection connection)
        {
            if(resultSet != null)
            {
                try {
                    resultSet.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

            if(statement != null)
            {
                try {
                    statement.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

            if(connection != null)
            {
                try {
                    connection.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }

        }
}

数据表数据存储对象

public class Sort {
    private int sid;
    private String sname;
    private double sprice;
    private String sdesc;
    private Date sdate;

    public int getSid() {
        return sid;
    }

    public void setSid(int sid) {
        this.sid = sid;
    }

    public String getSname() {
        return sname;
    }

    public void setSname(String sname) {
        this.sname = sname;
    }

    public double getSprice() {
        return sprice;
    }

    public void setSprice(double sprice) {
        this.sprice = sprice;
    }

    public String getSdesc() {
        return sdesc;
    }

    public void setSdesc(String sdesc) {
        this.sdesc = sdesc;
    }

    public Date getSdate() {
        return sdate;
    }

    public void setSdate(Date sdate) {
        this.sdate = sdate;
    }

    @Override
    public String toString() {
        return "Sort{" +
                "sid=" + sid +
                ", sname='" + sname + '\'' +
                ", sprice=" + sprice +
                ", sdesc='" + sdesc + '\'' +
                ", sdate=" + sdate +
                '}';
    }
}


 //增加
    public static int AddSort(Sort sort) throws SQLException {
        Connection connection = JDBCUtils.getConnection();
        PreparedStatement preparedStatement = connection.prepareStatement("insert into sort(sname,sprice,sdesc,sdate) values(?,?,?,?)");
        preparedStatement.setString(1,sort.getSname());
        preparedStatement.setDouble(2,sort.getSprice());
        preparedStatement.setString(3,sort.getSdesc());

        //java.util.date--->java.sql.date
        Date date = sort.getSdate();
        //得到date对应的时间戳
        long timestamp = date.getTime();
        //通过时间戳创建java.sql.Date类型的对象
        java.sql.Timestamp sqlDate = new java.sql.Timestamp(timestamp);
        preparedStatement.setTimestamp(4,sqlDate);

        int row = preparedStatement.executeUpdate();
        JDBCUtils.close(preparedStatement,connection);
        return row;
//增加
    public static void main(String[] args) throws SQLException {
        System.out.println("增加");
        Sort sort = new Sort();
        sort.setSname("小饰品");
        sort.setSprice(900);
        sort.setSdesc("好看");
        Date date = new Date();
        sort.setSdate(date);
        AddSort(sort);
    }
//删除
    public static int deleteSortByID(int id) throws SQLException {
        Connection connection = JDBCUtils.getConnection();
        PreparedStatement preparedStatement = connection.prepareStatement("delete from sort where sid = ?");
        preparedStatement.setInt(1,id);
        int row = preparedStatement.executeUpdate();
        JDBCUtils.close(preparedStatement,connection);
        return row;
    }
//删除
public static void main(String[] args) throws SQLException {
        System.out.println("删除");
        deleteSortByID(4);
    }
//更新(改)
    public static int updateSortByID(Sort sort) throws SQLException {
        Connection connection = JDBCUtils.getConnection();
        PreparedStatement preparedStatement = connection.prepareStatement("update sort set sname = ?,sprice = ?, sdesc=?,sdate = ? where sid = ?");
        preparedStatement.setString(1,sort.getSname());
        preparedStatement.setDouble(2,sort.getSprice());
        preparedStatement.setString(3,sort.getSdesc());
        Date date = sort.getSdate();
        //得到date对应的时间戳
        long timestamp = date.getTime();
        //通过时间戳创建java.sql.Date类型的对象
        java.sql.Timestamp sqlDate = new java.sql.Timestamp(timestamp);
        preparedStatement.setTimestamp(4,sqlDate);
        preparedStatement.setInt(5,sort.getSid());
        int row = preparedStatement.executeUpdate();
        JDBCUtils.close(preparedStatement,connection);
        return row;
    }
//更新
public static void main(String[] args) throws SQLException {
        System.out.println("更新");
        Sort sort = new Sort();
        sort.setSname("芭比娃娃");
        sort.setSprice(1400);
        sort.setSdesc("好看");
        Date date = new Date();
        sort.setSdate(date);
        sort.setSid(9);
        updateSortByID(sort);
     }
//查询——查一个
    public  static Sort getSortByID(int id) throws SQLException {
        Connection connection = JDBCUtils.getConnection();

        PreparedStatement preparedStatement = connection.prepareStatement("select * from sort where sid = ?");
        preparedStatement.setInt(1,id);

        ResultSet resultSet = preparedStatement.executeQuery();
        if (resultSet.next() == true)
        {
            int sid = resultSet.getInt("sid");
            String strName = resultSet.getString("sname");
            double dPrice = resultSet.getDouble("sprice");
            String sdesc = resultSet.getString("sdesc");

            Sort sort = new Sort();
            sort.setSid(sid);
            sort.setSname(strName);
            sort.setSprice(dPrice);
            sort.setSdesc(sdesc);
            return sort;
        }
        else
        {
            return null;
        }
    }
    //查询——查全部
    public static List<Sort> getAllSort() throws SQLException {
        Connection connection = JDBCUtils.getConnection();

        PreparedStatement preparedStatement = connection.prepareStatement("select * from sort");

        List<Sort> sortList = new ArrayList<>();

        ResultSet resultSet = preparedStatement.executeQuery();
        while (resultSet.next() == true)
        {
            int sid = resultSet.getInt("sid");
            String strName = resultSet.getString("sname");
            double dPrice = resultSet.getDouble("sprice");
            String sdesc = resultSet.getString("sdesc");
            Date date = resultSet.getTimestamp("sdate");

            Sort sort = new Sort();
            sort.setSid(sid);
            sort.setSname(strName);
            sort.setSprice(dPrice);
            sort.setSdesc(sdesc);
            sort.setSdate(date);
            sortList.add(sort);
        }
        return sortList;
    }

//查询
    public static void main(String[] args) throws SQLException {
        //查一个
        System.out.println("查一个");
        Sort sort = getSortByID(2);
        if(sort != null)
        {
            System.out.println(sort);
        }
        else
        {
            System.out.println("不存在");
        }
        //查全部
        System.out.println("查全部");
        List<Sort> sortList = getAllSort();
        for (Sort sort1: sortList)
        {
            System.out.println(sort1);
        }
db.properties
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybase?useUnicode=true&characterEncoding=UTF-8
username=root
password=root

java.util.date转为java.sql.date

Date date = sort.getSdate();
//得到date对应时间戳
long timestamp = date.getTime();
//通过时间戳创建java.sql.Date类型的对象
java.sql.Date  sqiDate = new java.sql.Date(timestamp);
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容

  • JDBC概念和数据库驱动程序 a:JDBC概述*JDBC(Java Data Base Connectivity ...
    金春国_Roy阅读 210评论 0 0
  • JDBC概念和数据库驱动程序 A: JDBC概念和数据库驱动程序a: JDBC概述JDBC(Java Data B...
    __豆约翰__阅读 705评论 0 7
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,598评论 18 399
  • 一望无际 多少人多少种无奈 也许昨天的我大标题叫做孤独 今天的我却笑着说感谢生活 每个人存在的方式大概就是深深浅浅...
    嘘是谁阅读 190评论 0 0
  • 我相信很少有人怀疑灵魂的存在。 但谁能知道人死后灵魂去了哪里呢? 你见过愤怒的狗和消沉的猫,可你见过微笑的猪吗? ...
    一声笑阅读 738评论 0 0