jdbc的增删改查_netbeans数据库增删改查

jdbc的增删改查_netbeans数据库增删改查JBDC数据的持久化:把数据保存到磁盘上。JDBC是java访问数据库的基石,JDO,Hibernate,Mybatis等都是基于JDBCJDBC是一个独立于特定数据库的管理系统,通用的SQL数据库存取和操作的公共接口配置文件:jdbc.propertiesuser=rootpassword=abc123url=jdbc:mysql://localhost:3306/testdriverClass=com.mysql.jdbc.Driver获取Connectionpublic s

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

JBDC


数据的持久化:把数据保存到磁盘上。
JDBC是java访问数据库的基石,JDO,Hibernate,Mybatis等都是基于JDBC
JDBC是一个独立于特定数据库的管理系统,通用的SQL数据库存取和操作的公共接口
在这里插入图片描述
在这里插入图片描述
配置文件:jdbc.properties

user=root
password=abc123
url=jdbc:mysql://localhost:3306/test
driverClass=com.mysql.jdbc.Driver

获取Connection

public static void main(String[] args) throws Exception { 
   
        //方式一
        Driver driver = new com.mysql.jdbc.Driver();
        String url = "jdbc:mysql://localhost1:3306/test";
        Properties info = new Properties();
        info.setProperty("user","root");
        info.setProperty("password","123456");
        Connection connect = driver.connect(url, info);


        //方式二:反射实现获取驱动对象 不用出现第三方的类
        Class clazz = Class.forName("com.mysql.jdbc.Driver");
        //权限要够
        Driver driver1 = (Driver) clazz.newInstance();


        //方式三:使用DriverManager替换Driver
        //获取驱动实现类对象
        Class clazz1 = Class.forName("com.mysql.jdbc.Driver");
        Driver driver2 = (Driver) clazz1.newInstance();
        String url1 = "jdbc:mysql://localhost1:3306/test";
        String user1 = "root";
        String password1 = "123456";
        //注册驱动
        DriverManager.registerDriver(driver2);
        //获取连接
        Connection connection = DriverManager.getConnection(url, user1, password1);
        System.out.println(connection);


        //方式4:优化方式四
        Class.forName("com.mysql.jdbc.Driver");
        //注册驱动
        DriverManager.registerDriver(driver2);
        //获取连接
        Connection connection1 = DriverManager.getConnection(url, user1, password1);
        System.out.println(connection1);

        //方式5:读取配置文件
        InputStream resourceAsStream = ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
        Properties properties = new Properties();
        properties.load(resourceAsStream);
        String user = properties.getProperty("user");
        String password = properties.getProperty("password");
        String url2 = properties.getProperty("url");
        String driverClass = properties.getProperty("driverClass");
        Class.forName(driverClass);
        Connection connection2 = DriverManager.getConnection(url, user, password);

    }

操作和访问数据库

在这里插入图片描述
PrepareStatement相比Statement能够解决SQL注入,拼串,能操作Blob数据,实现更高效的批量操作,

添加

public static void main(String[] args) throws Exception{ 
   
        InputStream resourceAsStream = ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties");
        Properties properties = new Properties();
        properties.load(resourceAsStream);
        String user = properties.getProperty("user");
        String password = properties.getProperty("password");
        String url = properties.getProperty("url");
        String driverClass = properties.getProperty("driverClass");
        Class.forName(driverClass);
        Connection connection = DriverManager.getConnection(url, user, password);
        
        //添加数据
        //预编译sql语句,PreparedStatement实例
        String sql = "insert into customers(name,email,birth) values(?,?,?)";
        java.sql.PreparedStatement preparedStatement = connection.prepareStatement(sql);
        //填充占位符
        preparedStatement.setString(1,"哪吒");
        preparedStatement.setString(2,"nezha@gmail.com");
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        Date date = sdf.parse("1000-01-01");
        preparedStatement.setDate(3, (java.sql.Date) new Date(date.getTime()));
        //执行sql
        preparedStatement.execute();
        preparedStatement.close();
        connection.close();
    }

修改

        //预编译sql语句,PreparedStatement实例
        String sql = "update customers set name = ? where id = ?";
        java.sql.PreparedStatement preparedStatement = connection.prepareStatement(sql);
        //填充占位符
        preparedStatement.setString(1,"莫扎特");
        preparedStatement.setObject(2,28);
        //执行sql
        preparedStatement.execute();
        preparedStatement.close();
        connection.close();

查找

//预编译sql语句,PreparedStatement实例
        String sql = "select id,name,email,birth from customers where id = ?";
        java.sql.PreparedStatement preparedStatement = connection.prepareStatement(sql);
        //填充占位符

        //执行sql
        ResultSet resultSet = preparedStatement.executeQuery();
        //获取结果集的元数据:ResultSetMetaData
        ResultSetMetaData rsmd = preparedStatement.getMetaData();
        int columnCount = rsmd.getColumnCount();
        while (resultSet.next()){ 
   
            Customer cust = new Customer();
            for(int i = 0;i < columnCount;i ++){ 
   
                Object object = resultSet.getObject(i + 1);

                //获取每个列的列明
                String columnName = rsmd.getColumnName(i + 1);

                Field declaredField = Customer.class.getDeclaredField(columnName);
                declaredField.setAccessible(true);
                declaredField.set(cust,object);
            }
        }

        preparedStatement.close();
        connection.close();
        resultSet.close();
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168941.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 网络分层架构(七/四层协议)

    网络分层架构(七/四层协议)网络分层架构业内普遍的分层方式有两种。OSI七层模型和TCP/IP四层模型。OSI七层模型:物、数、网、传、会、表、应TCP/IP四层模型:链、网、传、应1)物理层:主要定义物理设备标准,如网线的接口类型、光纤的接口类型、各种传输介质的传输速率等。它的主要作用是传输比特流(就是由1、0转化为电流强弱来进行传输,到达目的地后再转化为1、0,也就是我们常说的数模转换与模数转换)。这一层的…

    2022年6月21日
    32
  • 配置静态路由,动态路由,默认路由模式_默认路由为网络和掩码

    配置静态路由,动态路由,默认路由模式_默认路由为网络和掩码一、什么是路由路由(routing)是指分组从源到目的地时,决定端到端路径的网络范围的进程[1]。路由工作在OSI参考模型第三层——网络层的数据包转发设备。路由器通过转发数据包来实现网络互连。虽然路由器可以支持多种协议(如TCP/IP、IPX/SPX、AppleTalk等协议),但是在我国绝大多数路由器运行TCP/IP协议。路由器通常连接两个或多个由IP子网或点到点协议标识的…

    2022年9月16日
    2
  • mysql创建表的sql语句_mysql增删改查语句

    mysql创建表的sql语句_mysql增删改查语句打开数据库:步骤:新建查询(Ctrl+Q)→写SQL语句→运行→刷新→创建表成功创建表的SQL语句一般格式:CREATETABLE<表名>(<列名><数据类型>[列级完整性约束定义]{,<列名><数据类型>[列级完整性约束定义]…}[,表级完整性约束定义])下面来举个列子来说明一下就更清晰了,…

    2022年10月16日
    4
  • int和int32的区别_int是多少位的

    int和int32的区别_int是多少位的大家有没有写了很久代码,还不知道这个Int8,Int16,Int32,Int64有什么区别呢?或者是为什么后面的数字不一样呢?初步了解了一下,才清楚这个东西。先来扫盲一下计算机存储单元,  在计算机内部,信息都是釆用二进制的形式进行存储、运算、处理和传输的。信息存储单位有位、字节和字等几种。各种存储设备存储容量单位有KB、MB、GB和TB等几种计算机的基本的存储单元有:…

    2022年8月15日
    5
  • linux生成initramfs,Linux启动过程与initramfs

    linux生成initramfs,Linux启动过程与initramfsLinux启动过程概述这里先简单列一下Linux操作系统启动的全过程:按下电脑的电源键后,电脑通电,BIOS启动;BIOS读取硬盘的MBR,运行启动扇区中的代码,旧系统往往需要自己写启动扇区,而新系统基本上由专用的启动软件接管了,在Linux世界中,目前都是用的Grub2。由于启动扇区空间太小,放不下太复杂的代码逻辑,所以Grub2也使用了多阶段启动的策略;Grub2负责将操作系统…

    2022年8月11日
    5
  • 织梦CMS提示DedeTag Engine Create File False错误的解决办法总结

    织梦CMS提示DedeTag Engine Create File False错误的解决办法总结

    2021年9月19日
    46

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号