本帖最后由 小石姐姐 于 2018-12-13 09:41 编辑
数据库的特点:
1. 持久化存储数据的。其实数据库就是一个文件系统
2. 方便存储和管理数据
3. 使用了统一的方式操作数据库 -- SQL
Sql语句:
Sql :Structured Query Language:结构化查询语言
其实就是定义了操作所有关系型数据库的规则。每一种数据库操作的方式存在不一样的地方,称为“方言”。
sql分类
1) DDL(Data Definition Language)数据定义语言
用来定义数据库对象:数据库,表,列等。关键字:create, drop,alter 等
2) DML(Data Manipulation Language)数据操作语言
用来对数据库中表的数据进行增删改。关键字:insert, delete, update 等
3) DQL(Data Query Language)数据查询语言
用来查询数据库中表的记录(数据)。关键字:select, where 等
4) DCL(Data Control Language)数据控制语言(了解)
用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE 等
DDL
数据库
CREATE DATABASE 数据库名 CHARACTER SET utf8
DROP DATABASE 数据库名
SHOW DATABASES
SHOW CREATE DATABASE 数据库名
SELECT DATABASE()
USE 数据库名
表
CREATE TABLE 表名(列名 数据类型 约束,列名 数据类型 约束)
DROP TABLE 表名
SHOW CREATE TABLE 表名
SHOW TABLES
DESC 表名
ALTER TABLE 表名 ADD 列名 数据类型 约束
ALTER TABLE 表名 DROP 列名
ALTER TABLE 表名 MODIFY 列名 数据类型 约束
ALTER TABLE 表名 CHANGE 列名 新列名 数据类型 约束
ALTER TABLE 表名 CHARACTER SET utf8
RENAME TABLE 表名 TO 新表名
TRUNCATE TABLE 表名
DML
INSERT INTO 表名(列名...) VALUES(值...)
DELETE FROM 表名 WHERE 条件
UPDATE 表名 SET 列名 = 值 WHERE 条件
DQL
单表
SELECT 列名 FROM 表名 WHERE 条件 GROUP BY 列名 HAVING 条件 ORDER BY 列名 ASC/DESC LIMIT 索引,多少条 --
分页查询
1. 语法:limit 开始的索引,每页查询的条数;
2. 公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数
-- 每页显示3条记录
SELECT * FROM student LIMIT 0,3; -- 第1页
0是开始的索引,3是每页的查询条数
SELECT * FROM student LIMIT 3,3; -- 第2页
SELECT * FROM student LIMIT 6,3; -- 第3页
limit 是一个MySQL"方言"
多表
内连接
隐式
SELECT 列名 FROM 表名1,表名2 WHERE 关联条件 AND 条件
显式
SELECT 列名 FROM 表名1 JOIN 表名2 ON 关联条件 WHERE 条件
外链接
SELECT 列名 FROM 表名1 LEFT JOIN 表名2 ON 关联条件 WHERE条件
SELECT 列名 FROM 表名1 RIGHT JOIN 表名2 ON 关联条件 WHERE 条件
子查询
查询嵌套查询
条件: 单行单列,多行单列
虚拟表 多行多列
file:///C:/Users/Administrator/AppData/Local/YNote/data/qq43AEA454F9E8FC8D3CE99A4053144AD8/71a9dbfba826466dbe41468d5e50936e/wpsbcd4.tmp.jpeg
约束
概念: 对表中的数据进行限定,保证数据的正确性、有效性和完整性。
* 分类:
1. 主键约束:primary key
2. 非空约束:not null
3. 唯一约束:unique
4. 外键约束:foreign key
事务
如果一个包含多个步骤的业务操作,被事务管理,那么这些操作要么同时成功,要么同时失败。
操作:
1. 开启事务: start transaction;
2. 回滚:rollback;
3. 提交:commit;
MySQL数据库中事务默认自动提交
* 事务提交的两种方式:
* 自动提交:
* mysql就是自动提交的
* 一条DML(增删改)语句会自动提交一次事务。
* 手动提交:
* Oracle 数据库默认是手动提交事务
* 需要先开启事务,再提交
* 修改事务的默认提交方式:
* 查看事务的默认提交方式:SELECT @@autocommit; -- 1 代表自动提交 0 代表手动提交
* 修改默认提交方式: set @@autocommit = 0;
2. 事务的四大特征:
1. 原子性:是不可分割的最小操作单位,要么同时成功,要么同时失败。
2. 持久性:当事务提交或回滚后,数据库会持久化的保存数据。
3. 隔离性:多个事务之间。相互独立。
4. 一致性:事务操作前后,数据总量不变
3. 事务的隔离级别(了解)
* 概念:多个事务之间隔离的,相互独立的。但是如果多个事务操作同一批数据,则会引发一些问题,设置不同的隔离级别就可以解决这些问题。
* 存在问题:
1. 脏读:一个事务,读取到另一个事务中没有提交的数据
2. 不可重复读(虚读):在同一个事务中,两次读取到的数据不一样。
3. 幻读:一个事务操作(DML)数据表中所有记录,另一个事务添加了一条数据,则第一个事务查询不到自己的修改。
* 隔离级别:
1. read uncommitted:读未提交
* 产生的问题:脏读、不可重复读、幻读
2. read committed:读已提交 (Oracle)
* 产生的问题:不可重复读、幻读
3. repeatable read:可重复读 (MySQL默认)
* 产生的问题:幻读
4. serializable:串行化
* 可以解决所有的问题
* 注意:隔离级别从小到大安全性越来越高,但是效率越来越低
* 数据库查询隔离级别:
* select @@tx_isolation;
* 数据库设置隔离级别:
* set global transaction isolation level 级别字符串;
JDBC:
1. 概念:Java DataBase Connectivity Java 数据库连接, Java语言操作数据库
* JDBC本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。
1.注册驱动
[Java] 纯文本查看 复制代码 Class.forName("com.mysql.jdbc.Driver");
2.获取连接
[Java] 纯文本查看 复制代码 Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/dbname","root","123456");
3.定义sql,创建执行sql的对象
[Java] 纯文本查看 复制代码 Statemnet stmt = con.createStatemnet()
或PrepareStatement pst = con.preparedStatement(sql)
4.执行sql获取结果
dml
[Java] 纯文本查看 复制代码 int rows = stmt.executeUpdate("增删改sql")
int rows = pst.executeUpdate()
dql
[Java] 纯文本查看 复制代码 ResultSet rs = stmt.executeQuery("查sql")
ResultSet rs = pst.executeQuery()
5.处理结果
dml
[Java] 纯文本查看 复制代码 if(rows>0){
//成功
}
dql
while(rs.next()){
rs.getObject(1); //数字从*1*开始
rs.getObject("列名");
}
6.释放资源
[Java] 纯文本查看 复制代码 if(rs!=null){
try{
rs.close();
}catch(Ex..){
}
}
if(stmt!=null){
try{
stmt.close();
}catch(Ex..){
}
}
if(con!=null){
try{
con.close();
}catch(Ex..){
}
}
连接池
C3P0
接入步骤:
1.导jar
1.c3p0 2个
2.mysql驱动
2.导入配置文件(src目录下)
c3p0-config.xml
3.使用
[Java] 纯文本查看 复制代码 DataSource dataSource = new ComboPooledDataSource();
Connection con = dataSource.getConnection();
DRUID(德鲁伊)
接入步骤
1.导jar
1.druid
2.mysql驱动
2.导入配置文件(src)
druid.properties
3.使用
[Java] 纯文本查看 复制代码 Properties pro = new Properties();
pro.load(JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties"))
DataSource dataSource = DruidDataSourceFactory.createDataSoure(pro)
Connection con = dataSource.getConnection();
JdbcUtils实现思路
1.获取数据源(连接池) DataSource
2.获取连接对象 Connection
3.释放资源 重载
思路:
1,2:
DataSource在类加载的时候就应该初始化,为了保证对象能够及时创建,在 static{} 静态代码块中创建的对象
[Java] 纯文本查看 复制代码 Properties pro = new Properties();
pro.load(JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties"))
dataSource = DruidDataSourceFactory.createDataSoure(pro)
提供返回数据源的方法 getDataSource() ---> return dataSource
提供返回连接 getConnection() ---> return dataSource.getConnection()
3:
在关闭之前做非空判断!!!
JdbcTemplate
SPRING (基于jdbc来简化数据库的操作)
!!!如果有占位符需要传入参数
[Java] 纯文本查看 复制代码 DataSource dataSource = new ComboPooledDataSource();
JdbcTemplate template = new JdbcTemplate(dataSource);
增删改
template.update("sql",[具体参数]);
查询
单条结果
Map<String,Object> map = template.queryForMap("sql",[具体参数]);
Bean bean = template.queryForObject("sql",new BeanPropertyRowMapper<Bean>(Bean.class),[具体参数]);
多条结果
List<Map<String,Object>> list = template.queryForList("sql",[具体参数]);
List<Bean> list = template.query("sql",new BeanPropertyRowMapper<Bean>(Bean.class),[具体参数]);
|