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()——移动光标到上一行

原文地址:https://www.cnblogs.com/Clark-Shao/p/14881895.html