Java学习

Java学习之路


MySQL Workbench创建数据库

数据库连接代码


import java.sql.*;

public class MySQLDemo {

    // JDBC 驱动名及数据库 URL
    static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";
    static final String DB_URL = "jdbc:mysql://localhost/RUNOOB";//数据库连接

    // 数据库的用户名与密码,需要根据自己的设置
    static final String USER = "root";
    static final String PASS = "123456";

    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        try{
            // 注册 JDBC 驱动
            Class.forName("com.mysql.jdbc.Driver");

            // 打开链接
            System.out.println("连接数据库...");
            conn = DriverManager.getConnection(DB_URL);

            // 执行查询
            System.out.println(" 实例化Statement对...");
            stmt = conn.createStatement();
            String sql;
            sql = "SELECT id, name, url FROM websites";
            ResultSet rs = stmt.executeQuery(sql);

            // 展开结果集数据库
            while(rs.next()){
                // 通过字段检索
                int id  = rs.getInt("id");
                String name = rs.getString("name");
                String url = rs.getString("url");

                // 输出数据
                System.out.print("ID: " + id);
                System.out.print(", 站点名称: " + name);
                System.out.print(", 站点 URL: " + url);
                System.out.print("\n");
            }
            // 完成后关闭
            rs.close();
            stmt.close();
            conn.close();
        }catch(SQLException se){
            // 处理 JDBC 错误
            se.printStackTrace();
        }catch(Exception e){
            // 处理 Class.forName 错误
            e.printStackTrace();
        }finally{
            // 关闭资源
            try{
                if(stmt!=null) stmt.close();
            }catch(SQLException se2){
            }// 什么都不做
            try{
                if(conn!=null) conn.close();
            }catch(SQLException se){
                se.printStackTrace();
            }
        }
        System.out.println("Goodbye!");
    }
}


Mysql

  1. Mysql是最流行的关系型数据库管理系统,在WEB应用方面MySQL是最好的RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一。

  2. RDBMS即关系数据库管理系统(Relational Database Management System)的特点:
    1.数据以表格的形式出现
    2.每行为各种记录名称
    3.每列为记录名称所对应的数据域
    4.许多的行和列组成一张表单
    5.若干的表单组成database

  3. 插入数据

"INSERT INTO `websites` VALUES ('13', 'weibo', 'https://www.weibo.cm/', '18', 'CN')" ;

注意:

表名和字段名外面的符号 ` 不是单引号,而是英文输入法状态下的反单引号,也就是键盘左上角 esc 按键下面的那一个 ~ 按键,坑惨了。
反引号是为了区分 MySql 关键字与普通字符而引入的符号,一般的,表名与字段名都使用反引号。

动态SQL详解


servlet作用及配置
用servlet生成表现层页面显然是很麻烦的,因为都要用servlet的输出流来输出.
如上out.println("<html><body>"+kk+"</body></html>
");
servlet做控制层.jsp做表现层
,jsp编译后其实也是一个servlet.它其实充当了servlet做为表现层的工作.
servlet,是运行在服务器端的程序,用于处理及响应客户端的请求.
servlet应该是个中间的部分,对前面和后面部分起的交互,所以,很重要.
而且web.xml的配置都要经过这里,所以好好掌握.
简单配置:

<servlet>   
<servlet-name> servlet名字 </servlet-name>   
<servlet-class> 包名.类名 </servlet-class>   
</servlet>   
<servlet-mapping>   
<servlet-name> servlet名字 </servlet-name>   
<url-pattern> 由servlet处理的路径 </url-pattern>   
</servlet-mapping>   

把这段xml放在你的WEB-INF下面的web.xml里就行了当然还有其它一些别的东西`但是这是应用一个servlet基本的配置~~

<servlet>  
    <servlet-name>Contorller.wc</servlet-name>  
                           // 这里指定servlet的名称,这个名称随你喜欢,只要不重复就行  
    <servlet-class>web.Controller.Controller</servlet-class>  
                                          //这里servlet类的包路径和名称,注意大小写  
</servlet>  
//下面这两行配置的作用就是告诉web容器,在遇到<url-pattern>中的路径请求时就交给名为Contorller.wc的servlet来处理。  
<servlet-mapping>                                              
    <servlet-name>Contorller.wc</servlet-name>         
    <url-pattern>/Contorller.wc</url-pattern>  
</servlet-mapping>  

如果你的WEB项目是通过localhost:8080/web/index.jsp来访问的,那么上加上上面的servlet配置后,在IE地址栏中输入localhost:8080/web/Contorller.wc,web容器就会激发<servlet-class>指定的servlet来处理这个请求

web.xml配置各节点说明
Servlet编写过滤器

<filter>指定一个过滤器。
<filter-name>用于为过滤器指定一个名字,该元素的内容不能为空。
<filter-class>元素用于指定过滤器的完整的限定类名。
<init-param>元素用于为过滤器指定初始化参数,它的子元素<param-name>指定参数的名字,<param-value>指定参数的值。
在过滤器中,可以使用FilterConfig接口对象来访问初始化参数。
<filter-mapping>元素用于设置一个 Filter 所负责拦截的资源。一个Filter拦截的资源可通过两种方式来指定:Servlet 名称和资源访问的请求路径
<filter-name>子元素用于设置filter的注册名称。该值必须是在<filter>元素中声明过的过滤器的名字
<url-pattern>设置 filter 所拦截的请求路径(过滤器关联的URL样式)
<servlet-name>指定过滤器所拦截的Servlet名称。
<dispatcher>指定过滤器所拦截的资源被 Servlet 容器调用的方式,可以是REQUEST,INCLUDE,FORWARD和ERROR之一,默认REQUEST。用户可以设置多个<dispatcher>子元素用来指定 Filter 对资源的多种调用方式进行拦截。
<dispatcher>子元素可以设置的值及其意义
REQUEST:当用户直接访问页面时,Web容器将会调用过滤器。如果目标资源是通过RequestDispatcher的include()或forward()方法访问时,那么该过滤器就不会被调用。
INCLUDE:如果目标资源是通过RequestDispatcher的include()方法访问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。
FORWARD:如果目标资源是通过RequestDispatcher的forward()方法访问时,那么该过滤器将被调用,除此之外,该过滤器不会被调用。
ERROR:如果目标资源是通过声明式异常处理机制调用时,那么该过滤器将被调用。除此之外,过滤器不会被调用。

错误记录

  1. Error Code: 1046. No database selected Select the default DB to be used by double-clicking its name in the SCHEMAS list in the sidebar.
    原因 : 未选中数据库,双击才可选中,双击左侧建立好的数据库,在执行sql语句,即可执行成功
  2. Failed to initialize end point associated with ProtocolHandler
    原因: 端口被占用,要么关闭其他启动的tomcat,要么修改端口号Tomcat启动失败原因
  3. java.lang.ClassNotFoundException: org.apache.commons.fileupload.servlet.ServletFileUpload
    原因: 使用servlet的时候,如果导包,需要导入到 WEB-INF文件下下面
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值