标签:als count 执行sql 业务 class ble 目录 应用程序 root
JDBC是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。
加载JDBC驱动程序 → 建立数据库连接Connection → 创建执行SQL的语句Statement → 处理执行结果ResultSet → 释放资源
JDBC常用接口:
1.Driver接口
在编程中要连接数据库,必须先装载特定厂商的数据库驱动程序,不同的数据库有不同的装载方法。如:
MySql驱动:Class.forName("com.mysql.jdbc.Driver");
Oracle驱动:Class.forName("oracle.jdbc.driver.OracleDriver");
方式一:Class.forName(“com.MySQL.jdbc.Driver”);
方式二:DriverManager.registerDriver(com.mysql.jdbc.Driver);
2.Connection接口
Connection与特定数据库的连接(会话),在连接上下文中执行sql语句并返回结果。
连接MySql数据库:Connection conn = DriverManager.getConnection("jdbc:mysql://host:port/database", "user", "password");
连接Oracle数据库:Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@host:port:database", "user", "password");
连接SqlServer数据库:Connection conn = DriverManager.getConnection("jdbc:microsoft:sqlserver://host:port; DatabaseName=database", "user", "password");
常用方法:
3.Statement接口
用于执行静态SQL语句并返回它所生成结果的对象。
三种Statement类:
常用Statement方法:
4.ResultSet接口
ResultSet提供检索不同类型字段的方法,常用的有:
ResultSet还提供了对结果集进行滚动的方法:
使用后依次关闭对象及连接:ResultSet → Statement → Connection
数据库连接池技术
优点:
下面我们示范常用的C3p0的使用
c3p0.driverClass=com.mysql.jdbc.Driver c3p0.jdbcUrl=jdbc:mysql://localhost:3306/test c3p0.user=root c3p0.password=root
//创建一个数据库连接池ComboPooledDataSource ds = new ComboPooledDataSource(); QueryRunner qr = new QueryRunner(DataSourceUtils.getDataSource()); //通过接口可以执行查询或者更新,修改操作 qr.update(sql); //返回受影响的行数 qr.query(sql, null); //返回各种类型
public Category getById(String cid) throws Exception { QueryRunner qr = new QueryRunner(DataSourceUtils.getDataSource()); String sql = "select * from category where cid = ?";
return qr.query(sql, new BeanHandler<>(Category.class), cid); }
//封装成list
public List<Category> findAll() throws Exception { QueryRunner qr = new QueryRunner(DataSourceUtils.getDataSource()); String sql = "select * from category"; List<Category> list = qr.query(sql, new BeanListHandler<>(Category.class)); return list; }
/** * 查询数据总条数 返回单条数据 */ @Override public Integer getTotalSize() throws Exception { // 创建查询接口 QueryRunner qr = new QueryRunner(DataSourceUtils.getDataSource()); String sql = "select count(*) from links"; return ((Long) qr.query(sql, new ScalarHandler())).intValue(); }
标签:als count 执行sql 业务 class ble 目录 应用程序 root
原文地址:https://www.cnblogs.com/yuyangcoder/p/9868706.html