zoukankan      html  css  js  c++  java
  • 20210206日报

    这个主要学习是关于listview的学习。

    怎样去自定义adapter,以及使用。自己创建文件,还有就是为listview的每一个子控件添加点击事件。

    在整个过程中收获到的知识点如下:

    一、对于数据库查找方面的知识点:

    ORDER BY从句后跟要排序的列。ORDER BY 从句出现在SELECT语句的最后。 
    排序有升序和降序之分,ASC表示升序排序,DESC表示降序排序。如果不指明排序顺序,默认的排序顺序为升序ASC。如果要降序,必须书写DESC关键字

    对于一些网上的例子:这样更容易理解:

    悄悄的成长い 2020/2/6 9:18:52
    1.升序排序 
    【训练1】 查询雇员姓名和工资,并按工资从小到大排序。 
    输入并执行查询: 

    Sql代码
    SELECT ename, sal FROM emp ORDER BY sal;

    悄悄的成长い 2020/2/6 9:19:03
    注意:若省略ASC和DESC,则默认为ASC,即升序排序。 
    2.降序排序 
    【训练2】 查询雇员姓名和雇佣日期,并按雇佣日期排序,后雇佣的先显示。 
    输入并执行查询: 

    Sql代码
    SELECT ename,hiredate FROM emp ORDER BY hiredate DESC;

    悄悄的成长い 2020/2/6 9:19:17
    注意: DESC表示降序排序,不能省略。 
    3.多列排序 
    可以按多列进行排序,先按第一列,然后按第二列、第三列......。 
    【训练3】 查询雇员信息,先按部门从小到大排序,再按雇佣时间的先后排序。 
    输入并执行查询: 

    Sql代码
    SELECT ename,deptno,hiredate FROM emp ORDER BY deptno,hiredate;

    悄悄的成长い 2020/2/6 9:20:04
    说明:该排序是先按部门升序排序,部门相同的情况下,再按雇佣时间升序排序。 
    4.在排序中使用别名 
    如果要对计算列排序,可以为计算列指定别名,然后按别名排序。 
    【训练4】 按工资和工作月份的乘积排序。 
    输入并执行查询: 

    Sql代码
    SELECT empno, ename, sal*Months_between(sysdate,hiredate) AS total FROM emp   
            ORDER BY total;
    但是自己实际应用时候的写法是“mingzi  asc”这两个是写在一个括号里面,中间用空格分开。

    二、关于一个类继承一个接口的时候的操作:

    Serializable是Java提供的序列化接口,是一个空接口,为对象提供标准的序列化与反序列化操作。使用Serializable实现序列化过程相当简单,只需要在类声明的时候指定一个标识,便可以自动的实现默认的序列化过程。

    private static final long serialVersionUID = 1L;
           上面已经说明让对象实现序列化,只需要让当前类实现Serializable接口,并且声明一个serialVersionUID就可以了,非常的简单方便。实际上serialVersionUID都不是必须的,没有它同样可以正常的实现序列化操作。

          User类就是一个实现了Serialzable的类,它是可以被序列化和反序列化的。

    public class User implements Serializable {
     
        private static final long serialVersionUID = 1L;
     
        private String userId;
        private String userName;
     
    }
           通过Serializable实现对象的序列化过程非常的简单,无需任何操作,系统就为我们自动实现了。如何进行对象的序列化与反序列化操作也是非常的简单,只需要通过ObjectOutputStream,ObjectInputStream进行操作就可以了。

     //序列化过程
        public void toSerial() {
            try {
                User user = new User("id", "user");
                ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("user.txt"));
                objectOutputStream.writeObject(user);
                objectOutputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
     
        //反序列化过程
        public void fromSerial(){
            try {
                ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("user.txt"));
                User user = (User) objectInputStream.readObject();
                objectInputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }

    三、关于cuosor的相关知识点

    Cursor 是每行的集合。使用 moveToFirst() 定位第一行。你必须知道每一列的名称。你必须知道每一列的数据类型。Cursor 是一个随机的数据源。所有的数据都是通过下标取得。
    关于 Cursor 的重要方法:
    ·close()——关闭游标,释放资源
    ·copyStringToBuffer(int columnIndex, CharArrayBuffer buffer)——在缓冲区中检索请求的列的文本,将将其存储
    ·getColumnCount()——返回所有列的总数
    ·getColumnIndex(String columnName)——返回指定列的名称,如果不存在返回-1
    ·getColumnIndexOrThrow(String columnName)——从零开始返回指定列名称,如果不存在将抛出IllegalArgumentException 异常。
    ·getColumnName(int columnIndex)——从给定的索引返回列名
    ·getColumnNames()——返回一个字符串数组的列名
    ·getCount()——返回Cursor 中的行数
    ·moveToFirst()——移动光标到第一行
    ·moveToLast()——移动光标到最后一行
    ·moveToNext()——移动光标到下一行
    ·moveToPosition(int position)——移动光标到一个绝对的位置
    ·moveToPrevious()——移动光标到上一行

  • 相关阅读:
    VSFTP日志文件详解
    RocketMQ多master多salve集群搭建
    数据持久化之bind Mounting
    数据持久化之Data Volume
    gitLab 分支保护设置
    docker容器的端口映射
    docker命令之link
    NFS客户端挂载失败之authenticated unmount request from
    docke网络之bridge、host、none
    docke通信之Linux 网络命名空间
  • 原文地址:https://www.cnblogs.com/Clark-Shao/p/14881895.html
Copyright © 2011-2022 走看看