数据库
关系型数据库 <---> NoSQL
1.集合论+关系代数
2.用二维表保存数据
- 一行是一条记录
- 一列是一个字段
关系型数据库产品
- MySQL(LAMP = Linux + Apache + MySQL +PHP)
- Oracle
- DB2
- SQL Server
关系型数据库编程语言 - SQL - 结构化查询语言
DDL(数据定义语言)create/drop/alter
DML(数据操作语言)insert/delete/update
DQL(数据查询语言)select
DCL(数据控制语言)grant/revoke
MySQL客户端GUI工具
- Navicat for MySQL
- Toad for MySQL
- SQLyog
SQL命令:
显示所有数据库 show databases;
创建数据库 create database house;
使用数据库 use house;
显示所有表 show tables;
创建表
create table tb_user`
(
userid integer primary key auto_increment,
username varchar(20) not null unique,
password varchar(20) not null,
tel char(11),
realname varchar(50) default '无名氏'
);
描述表 desc tb_user;
看一下怎么建表 show create table tb_user;
新增(插入)记录
insert into tb_user values (default,'admin','123456','13124355678','Kygo');
insert into tb_user (username,password) values ('kygo','123123');
查询所有列 select * from tb_user;
删除表中的记录(行) delete from tb_user where username='kygo';
更新表中的记录
update tb_user set password='654321',tel='18912344564' where
username='admin';
删除表 drop table tb_user;
JDBC - Java DataBase Connectivity
0.将驱动程序放置到类路径中 - JDBC规范针对某种特定数据库的实现版本
1.加载驱动 - Class.forName(String)
2.建立连接 - DriverManager.getConnection(url, uid, pwd)
3.发SQL语句 - createStatement() / prepareStatement(String)
- executeQuery() / - executeUpdate()
4.处理结果集(对游标进行迭代)- next() / getXXX(String)
5.释放连接 - close()
例子1:
Connection con = null;
try {
// 1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
// 2.建立连接
con = DriverManager.getConnection("jdbc:mysql://localhost:3306/house",
"root", "123456");
// 3.发SQL语句
Statement stmt = con.createStatement();
// 如果执行查询将得到结果集(游标)对象
ResultSet rs = stmt.executeQuery("select userid,username, password from tb_user");
// 4.对结果集进行迭代从每一行中取出对应的列
while (rs.next()) {
System.out.print(rs.getInt("userid") + "\t");
System.out.print(rs.getString("username") + "\t");
System.out.println(rs.getString("password"));
System.out.println("==================");
}
// 说明: 如果Connection对象需要保留继续使用 此处应该先关闭ResultSet和Statement
// 如果Connection对象不需要使用了那么就直接关闭Connection对象
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} finally {
// 5.释放连接
try {
if (con != null && !con.isClosed()) {
con.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
例子2:
Scanner sc = new Scanner(System.in);
Connection con = null;
try {
Class.forName("com.mysql.jdbc.Driver");
con = DriverManager.getConnection("jdbc:mysql://localhost:3306/house?useUnicode=true&characterEncoding=utf-8",
"root", "123456");
String username = sc.next();
String password = sc.next();
String tel = sc.next();
String realname = sc.next();
PreparedStatement stmt = con.prepareStatement(
"insert into tb_user values (default,?,?,?,?)");
stmt.setString(1, username);
stmt.setString(2, password);
stmt.setString(3, tel);
stmt.setString(4, realname);
if (stmt.executeUpdate() == 1) {
System.out.println("新增用户成功!");
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} finally {
try {
if (con != null && !con.isClosed()) {
con.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
sc.close();
}
跳转和重定向
服务器端跳转
req.getRequestDispatcher("add.jsp").forward(req, resp);
重定向(发送一个新的URL给浏览器让浏览器重新请求新页面)
resp.sendRedirect("add.jsp");