java暑期学习笔记(10)

# 2018/07/20 #
* **1.JDBC**
    * JDBC:java database connectivity
    * JDBC与数据库驱动的关系:接口与实现的关系。
    * JDBC规范(掌握四个核心对象):
        * DriverManager:用于注册驱动(类)
        * Connection: 表示与数据库创建的连接(接口)
        * Statement: 操作数据库sql语句的对象(接口)
        * ResultSet: 结果集或一张虚拟表(接口)
    * 把jar包放在lib里,然后右键buildpath
    * 实现JDBC操作
        * 1、注册驱动  class forName("com.mysql.jdbc.Driver");
        * 2、创建连接
            * DriverManager.getConnection("jdbc:mysql://localhost:3306/test?user=root&password=12345");
            * jdbc:mysql://localhost:3306/test
                协议 子协议  IP :端口号 数据库
        * 3、得到执行sql语句的Statement对象
            * Statement  createStatement(); 创建操作sql语句的对象
            * ResultSet  executeQuery(String sql); 根据查询语句返回结果集。
            * int executeUpdate(String sql) 根据执行的DML(insert update delete)语句,返回受影响的行数。
            * boolean execute(String sql)  此方法可以执行任意sql语句。返回boolean值,表示是否返回ResultSet结果集。仅当执行select语句,且有返回结果时返回true, 其它语句都返回false;
        * 4、执行sql语句,并返回结果
        * 5、处理结果
        * 6、关闭资源
* **2.junit**
    * 在方法上添加@test,导库,点方法名右键运行,可以测试方法
    * 要求:不能有返回值,不能有参数
* **3.结果集**
    * Object getObject(String ColomnName); 根据列名取值。
    * 将结果集中的数据封装到javaBean中
    * int getInt(String colLabel)    以int形式获取ResultSet结果集当前行指定列名值
    * String getString(String colLabel)    以String形式获取ResultSet结果集当前行指定列名值
    * Date getDate(String columnName);
    * void close()    关闭ResultSet 对象
     * 可移动游标的方法
         * boolean next()  将光标从当前位置向前移一行。 
         * boolean previous() 将光标移动到此 ResultSet 对象的上一行。 
        * boolean absolute(int row) 参数是当前行的索引,从1开始根据行的索引定位移动的指定索引行。
         * void afterLast() 将光标移动到末尾,正好位于最后一行之后。 
         * void beforeFirst()将光标移动到开头,正好位于第一行之前。
* **5.CURD**
    * 提取DButils.java文件,把连接数据库和关闭数据库的操作抽取出来
    * 可以创建一个properties文件存放变量,在静态代码块new一个ResourceBundle对象,getBundle获取properties文件,再通过getString方法得到文件中的属性值。
* **6.SQL注入问题:preparedStatement**
    * preparedStatement:预编译对象, 是Statement对象的子类
    * 特点:性能要高,会把sql语句先编译,sql语句中的参数会发生变化,过滤掉用户输入的关键字。
    * sql="select * from users where name=? ";stmt.setString(1,name);给?赋值,有几个问号就set几次。
* **7.XML**
    * 可扩展,所有标签都是自定义的。
    * 功能:数据储存
        * 配置文件
        * 数据传输
    * html与xml区别:
        * html语法松散,xml语法严格
        * html做页面展示,xml做数据存储
        * html所有标签都是预定义的,xml所有标签都是自定义的 
    * xml语法:
        * 文档声明:
            * 必须写在xml文档的第一行。
            * 写法:<?xml version="1.0" ?>
            * 属性:    
                * version:版本号 固定值 1.0
                * encoding:指定文档的码表。默认值为 iso-8859-1
                * standalone:指定文档是否独立  yes 或 no
        * 元素:xml文档中的标签
            * 文档中必须有且只能有一个根元素
            * 元素需要正确闭合。
            * 元素需要正确嵌套
            * 元素名称要遵守:
                * 元素名称区分大小写
                * 数字不能开头
        * 文本:
            * 转义字符:大于号&gt;小于号&lt;
            * CDATA: 里边的数据会原样显示
                *  <![CDATA[ 数据内容 ]]>        
        * 属性:
            * 属性值必须用引号引起来。单双引号都行
        * 注释:<!-- -->
    * xml约束:xml的书写规则
        * 约束的分类:
            * dtd:
                * 内部dtd:在xml内部定义dtd
                * 外部dtd:在外部文件中定义dtd
                    * 本地dtd文件:<!DOCTYPE students SYSTEM  "student.dtd">
                    * 网络dtd文件:<!DOCTYPE students PUBLIC "名称空间" "student.dtd">
            * schema:导入xsd约束文档:
                * 1、编写根标签
                * 2、引入实例名称空间 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                * 3、引入名称空间 xsi:schemaLocation="http://www.itcast.cn/xml student.xsd"    
                * 4、引入默认的名称空间 xmlns=名称:"http://www.itcast.cn/xml"导入多个的时候可以使用名称,标签里边要加<名称:...>
* **8.XML解析**            
    * xml解析思想:
        * DOM:将文档加载进内存,形成一颗dom树(document对象),将文档的各个组成部分封装为一些对象。
            * 优点:因为,在内存中会形成dom树,可以对dom树进行增删改查。
            * 缺点:dom树非常占内存,解析速度慢。
        * SAX:逐行读取,基于事件驱动
            * 优点:不占内存,速度快
            * 缺点:只能读取,不能回写
    * xml常用的解析器:
        * DOM4J:dom for java非常好。支持dom
            * 1.导入jar包 dom4j.jar
            * 2.创建解析器
                SAXReader reader = new SAXReader();
            * 3.解析xml 获得document对象 
                Document document = reader.read(url);
                Elements root = document.getRootElement();得到节点
* **9.XPATH:专门用于查询**
    * 定义了一种规则
        * 使用的方法: 
            * selectSingleNode():
            * selectNodes():
    * 使用步骤:
        * 1、注意:要导包 jaxen...jar
        * 2、创建解析器
            SAXReader reader = new SAXReader();
        * 3、解析xml 获得document对象 
            Document document = reader.read(url);
    *     nodename 选取此节点。
        /     从根节点选取。
        //     从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。
        ..     选取当前节点的父节点。
        @     选取属性。
    [@属性名]    属性过滤
    [标签名]     子元素过滤
* **10.web目录结构**
    * WEB-INF:此目录下的文件不能被外部直接访问
    * webroot里边的文件拷贝到tomcat的webapps里边然后就可以访问了
    * URI当前应用的资源路径
    * 当webapps内存不够时,新建一个myapp.xml,<Context docBase="新的路径"/>然后放在Tomcat\conf\Catalina\localhost目录下

猜你喜欢

转载自www.cnblogs.com/yaopeiyun/p/9557141.html
今日推荐