Web学习笔记 - 第002天

数据库

关系型数据库 <---> 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");

你可能感兴趣的:(Web学习笔记 - 第002天)