在这一篇博客中我将对数据库进行一个结尾,这将是关于数据库基本内容的结尾。
首先我们来简单总结一下前面的内容:
前面主要讲了Mysql中的索引和事务,这是面试必考的内容。
索引,怎么理解索引呢?
1.索引存在的意义:为了提高查找的效率
2.索引需要付出的代价
a.空间的代价:索引是为了方便查找,用空间来换取时间
b.时间代价:针对增删改
3.索引虽然付出的代价很多,但是在实际的工作中,索引任然会得到广泛的使用,实际需求中,经常“一写多读”
4.索引背后的数据结构 B+树
a.其他的结构可以嘛?
二叉搜索树(AVL树,红黑树)不太性,树的高度太高,导致IO访问的次数更多。哈希表也不可以,因为哈希表不可以进行范围查找
b..B树的介绍
N叉搜索树,每个节点上包含了N个记录,N个记录就分成了N+1个区间,对应到N+1个子树,通过这种方式来快速确定当前需要查找到的值在哪个区间,进一步进行快速筛选。
c.B+树的介绍
B+树是在B树的基础上做出的改进,首先,每个节点上包含了N个key,N个key分成了N个区间,其次,每个节点上的值,都会在子节点上体现,叶子节点上包含所有数据的全集,最后,叶子节点再通过链表的形式来进行收尾相连。
此时带来最大的好处,一方面,可以更高效的进行范围查找,另一方面,因为叶子节点是数据的全集,非叶子节点就只保存key,占用的空间少,可以在内存中进行缓存,又进一步的减少IO次数。
5.什么是事务
a.事务是要将多个SQL打包成一个,要么都进行执行,要么都不执行
b.事务的应用场景,典型就是转账、
c.事务是如何实现保障上述机制的呢?核心就是回滚,回滚的依据就是mysql要记录治安执行的一些过程
d.事务的几个基本特性:原子性,一致性,持久性,隔离性
这边重点再说一下隔离性:其中有三个重要的问题
脏读,给写操作加锁;
不可重复读,给读操作也加锁;
幻读,串行化
read uncommitted;read committed;repeatable read;serializable;通过这四个,mysql的配置文件来设置这里的隔离级别。
这边只是简单的介绍一下,如果需要详细的,可以读一下上一篇博客。
下面来开始今天的内容:
JDBC编程
首先我们需要先创建一个项目,之后去中央仓库中下载一下驱动包,但是有一个比较重要的需要注意一下,要根据MySQL版本来下载驱动包,之后去创建一个lib目录,之后将下载的驱动包复制到lib中,最后最重要的是
需要点最下面的add,接下来就是进行代码的编写了。
JDBC的基本编程流程
//1.创建数据库
DataSource dataSource=new MysqlDataSource();
//设置数据库的地址
((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSl=false");
//设置登录数据库的命名
((MysqlDataSource)dataSource).setUser("root");
//设置登录数据库的密码
((MysqlDataSource)dataSource).setPassword("123456");
首先需要创建DataSource对象,之后确定数据库的位置,其中setUser和setPassword很好理解, 就是你数据库的账户和密码,下面来重点讲解一下
jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSl=false
一般来说,这个不用进行修改,直接复制使用就行。
//2.让代码和数据库服务器创建连接
Connection connection=dataSource.getConnection();
这个代码是让代码和数据库服务器之间创建连接
我们需要选择第一个,但是创建结束之后我们会发现会有报错,之后右键进行
//4.执行sql
//SQL中的insert,update,delete这些操作需要使用executeUpdate
//SQL中的delete使用executeQuery
int ret=statement.executeUpdate(sql);
System.out.println(ret);
返回的ret是操作的次数
最后需要的是创建出来的空间进行释放
//5.释放空间
statement.close();;
connection.close();
这个顺序是不可以进行换位置的
下面来看一下整体的代码
public static void main(String[] args) throws SQLException {
//1.创建数据库
DataSource dataSource=new MysqlDataSource();
//设置数据库的地址
((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSl=false");
//设置登录数据库的命名
((MysqlDataSource)dataSource).setUser("root");
//设置登录数据库的密码
((MysqlDataSource)dataSource).setPassword("123456");
//2.让代码和数据库服务器创建连接
Connection connection=dataSource.getConnection();
//3.操作数据库,以插入数据为例
String sql="insert into student values(1,'张三')";
//之后需要将sql包装成一个“语句对象”
PreparedStatement statement=connection.prepareStatement(sql);
//4.执行sql
//SQL中的insert,update,delete这些操作需要使用executeUpdate
//SQL中的delete使用executeQuery
int ret=statement.executeUpdate(sql);
System.out.println(ret);
//5.释放空间
statement.close();;
connection.close();
但是我们不可以每次都自己输入内容,如果需要用户输入我们需要更改一下代码,下面来展示一下insert,update,delete,selete的代码
insert代码
Scanner scanner=new Scanner(System.in);
//1.创建好数据库
DataSource dataSource=new MysqlDataSource();
//设置数据库所在的地址
((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSl=false");
//设置登录数据库的用户名
((MysqlDataSource)dataSource).setUser("root");
//设置登录数据库的密码
((MysqlDataSource)dataSource).setPassword("123456");
//2.让代码和数据库服务器创建连接
Connection connection=dataSource.getConnection();
//2.5让用户通过控制台输入待插入的数
System.out.println("请输入学号");
int id= scanner.nextInt();
System.out.println("请输入姓名");
String name=scanner.next();
//3.操作数据库,以插入数据为例
//关键所在就是创建一个SQL语句
String sql="insert into student values(?,?)";
//此处光是一个String类型的sql还不行,需要把这个String包装成一个”语句对象“
PreparedStatement statement=connection.prepareStatement(sql);
//进行替换操作
statement.setInt(1,id);
statement.setString(2,name);
System.out.println("statement: "+statement);
//4.执行SQL,相当于扫码取件
//SQL里面如果是insert,update,delete使用executeUpdate方法
//SQL里面如果是select,使用executeQuery方法
//返回值就表示这个操作,影响了几行就相当于在控制台输入sql之后得到的数字
int ret=statement.executeUpdate();
System.out.println(ret);
//5.释放需要释放的资源
statement.close();;
connection.close();
delete代码
//删除数据库
//让用户来输入一个id,之后根据id来进行删除
//1.创建数据源
DataSource dataSource=new MysqlDataSource();
((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSl=false");
((MysqlDataSource)dataSource).setUser("root");
((MysqlDataSource)dataSource).setPassword("123456");
//2.建立连接
Connection connection=dataSource.getConnection();
//3.用户输入id
Scanner scanner=new Scanner(System.in);
System.out.println("输入想要删除的用户id:");
int id= scanner.nextInt();
//4.拼装sql语句
String sql="delete from student where id = ?";
PreparedStatement statement=connection.prepareStatement(sql);
statement.setInt(1,id);
//5.执行sql
int ret=statement.executeUpdate();
System.out.println("ret = "+ret);
//6.释放
statement.close();
connection.close();
update代码
DataSource dataSource=new MysqlDataSource();
((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSl=false");
((MysqlDataSource)dataSource).setUser("root");
((MysqlDataSource)dataSource).setPassword("123456");
Connection connection=dataSource.getConnection();
Scanner scanner=new Scanner(System.in);
System.out.println("需要修改的id:");
int id=scanner.nextInt();
System.out.println("修改后的name:");
String name= scanner.next();
String sql="update student set name = ? where id = ?";
PreparedStatement statement=connection.prepareStatement(sql);
statement.setString(1,name);
statement.setInt(2,id);
System.out.println("statement: "+statement);
int ret=statement.executeUpdate();
System.out.println("ret="+ ret);
statement.close();
connection.close();
select代码
//1.创建数据源
DataSource dataSource=new MysqlDataSource();
((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/java?characterEncoding=utf8&useSSl=false");
((MysqlDataSource)dataSource).setUser("root");
((MysqlDataSource)dataSource).setPassword("123456");
//2.创建连接
Connection connection=dataSource.getConnection();
//3.拼接sql
String sql="select * from student";
PreparedStatement statement=connection.prepareStatement(sql);
//4.执行sql,对于查询操作,就需要使用executeQuery
//查询操作返回的不是int,而是一个临时表
//使用ResultSet表示这个表
ResultSet resultSet= statement.executeQuery();
//5.遍历结果集合
while(resultSet.next()){
int id=resultSet.getInt("id");
String name=resultSet.getString("name");
System.out.println("id = "+id+", name = "+name);
}
//6.释放资源
resultSet.close();
statement.close();
connection.close();