SQL 查找两表中不同的数据

SQL 查找两表中不同的数据,第1张

使用except函数,select from B where (select count(1) from A where AID = BID) = 0

方法一(推荐)

WITH   C AS ( SELECT   Name

FROM     ConsumerCouponApply A

WHERE    NOT EXISTS ( SELECT 1

FROM   ConsumerCouponApply B

WHERE  BName = AName

GROUP BY BName )

GROUP BY AName

)

SELECT  COUNT(1)

FROM    C

方法二

WITH    C AS ( SELECT   AName

FROM     ConsumerCouponApply A

GROUP BY AName

EXCEPT

SELECT   BName

FROM     ConsumerCouponApply B

GROUP BY BName

)

SELECT  COUNT(1)

FROM    C

方法三

SELECT  COUNT(AName)

FROM    ConsumerCouponApply A

LEFT JOIN ConsumerCouponApply B ON AName = BName

WHERE   BID IS NULL

扩展资料:

高级查询运算词:

A: UNION 运算符:

UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个

结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行

不是来自 TABLE1 就是来自 TABLE2。

B: EXCEPT 运算符

EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。

C: INTERSECT 运算符

INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当

ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。

注:使用运算词的几个查询结果行必须是一致的。

1、在我们的电脑上打开数据库,这里新建一张含有重复数据的user表做示例。

2、我们输入“select from user where name in (select name from user group by name having count(name) > 1) ”sql语句,点击运行可以看到查询出了数据库中user表的重复数据。

3、通过“delete from user where   name in (select name from user group by name  having count(name) > 1) ”sql语句删除姓名重复的数据。

4、通过“select distinct name from user”sql语句来去掉重复数据,这里去掉了张三的重复数据。

5、通过“select distinct class from user”sql语句来去掉班级相同的重复数据。

6、也可以通过“select distinct name,class from user”来去掉两个字段的重复数据。

不是很明白你的要求。具体的 *** 作是怎样的的呢?

假设数据库中有个学生表:

学号  姓名  年龄

001  张三  20

002  李四  21

假设按姓名搜索,输入搜索条件“张”:

情况1、根据搜索条件直接搜索数据库记录(通常都是这样搜索),那从数据库搜索出的记录就只有姓名包含“张”的记录,然后JTable中也就只展示这些记录,就无所谓置顶不置顶啦。

情况2、只是根据搜索条件在当前JTable展示的数据中搜索,代码如下:

import javaawtBorderLayout;

import javaawtGridLayout;

import javaawteventActionEvent;

import javaawteventActionListener;

import javaxswingJButton;

import javaxswingJFrame;

import javaxswingJLabel;

import javaxswingJPanel;

import javaxswingJScrollPane;

import javaxswingJTable;

import javaxswingJTextField;

import javaxswingborderEmptyBorder;

import javaxswingeventTableModelEvent;

import javaxswingeventTableModelListener;

 public class JTableTest extends JFrame {

  private JPanel searchPanel;

  private JTextField numField;

  private JButton searchByNumButton;

  private JTextField nameField;

  private JButton searchByNameButton;

  private JTable table;

  private TestTableModel tableModel;

  public JTableTest() {

    super("Simple JTable Test");

    setSize(400, 300);

    setDefaultCloseOperation(DISPOSE_ON_CLOSE);

    searchPanel = new JPanel();

    searchPanelsetBorder(new EmptyBorder(3, 3, 3, 3));

    searchPanelsetLayout(new GridLayout(2, 3, 2, 3));

    searchPaneladd(new JLabel("学号"));

    numField = new JTextField(20);

    searchPaneladd(numField);

    searchByNumButton = new JButton("按学号搜索");

    searchByNumButtonaddActionListener(new ActionListener() {

      public void actionPerformed(ActionEvent event) {

        tablegetSelectionModel()clearSelection();

        tableModeldoSearchByNum(numFieldgetText());

      }

    });

    searchPaneladd(searchByNumButton);

    searchPaneladd(new JLabel("姓名"));

    nameField = new JTextField(20);

    searchPaneladd(nameField);

    searchByNameButton = new JButton("按姓名搜索");

    searchByNameButtonaddActionListener(new ActionListener() {

      public void actionPerformed(ActionEvent event) {

        tablegetSelectionModel()clearSelection();

        tableModeldoSearchByName(nameFieldgetText());

      }

    });

    searchPaneladd(searchByNameButton);

    getContentPane()add(searchPanel, BorderLayoutNORTH);

    tableModel = new TestTableModel();

    tableModeladdTableModelListener(new TableModelListener() {

      @Override

      public void tableChanged(TableModelEvent e) {

        if (tableModelgetHitRowCount() > 0) {

          tablesetRowSelectionInterval(0, tableModelgetHitRowCount() - 1);

        }

      }

    });

    table = new JTable(tableModel);

    JScrollPane jsp = new JScrollPane(table);

    getContentPane()add(jsp, BorderLayoutCENTER);

  }

  public static void main(String[] args) {

    JTableTest self = new JTableTest();

    selfsetVisible(true);

  }

}import javautilArrayList;

import javautilArrays;

import javautilList;

import javaxswingtableAbstractTableModel;

public class TestTableModel extends AbstractTableModel {

  private List<Student> data = ArraysasList(new Student("001", "王二", 20), new Student("002",

      "王二小", 19), new Student("003", "张三", 20), new Student("004", "张三丰", 21), new Student("005",

      "李四", 21), new Student("006", "李四光", 19));

  private List<Integer> searchHitRows = new ArrayList<Integer>();

  @Override

  public int getRowCount() {

    return datasize();

  }

  @Override

  public int getColumnCount() {

    return 3;

  }

  @Override

  public String getColumnName(int column) {

    if (column == 0)

      return "学号";

    else if (column == 1)

      return "姓名";

    return "年龄";

  }

  @Override

  public Object getValueAt(int rowIndex, int columnIndex) {

    Student student = dataget(rowIndex);

    if (columnIndex == 0)

      return studentgetNum();

    else if (columnIndex == 1)

      return studentgetName();

    return studentgetAge();

  }

  / 按姓名搜索 /

  public void doSearchByName(String key) {

    searchHitRowsclear();

    if (key == null || ""equals(key))

      return;

    for (int i = 0; i < datasize(); i++) {

      Student studentI = dataget(i);

      String value = studentIgetName();

      if (valueindexOf(key) < 0)

        continue;

      int j = 0;

      for (j = i - 1; j >= 0; j--) {

        Student studentJ = dataget(j);

        String valueJ = studentJgetName();

        if (valueJindexOf(key) >= 0)

          break;

      }

      Student temp = dataget(j + 1);

      dataset(j + 1, studentI);

      dataset(i, temp);

      searchHitRowsadd(IntegervalueOf(j + 1));

    }

    fireTableDataChanged();

  }

  / 按学号搜索 /

  public void doSearchByNum(String key) {

    searchHitRowsclear();

    if (key == null || ""equals(key))

      return;

    for (int i = 0; i < datasize(); i++) {

      Student studentI = dataget(i);

      String value = studentIgetNum();

      if (valueindexOf(key) < 0)

        continue;

      int j = 0;

      for (j = i - 1; j >= 0; j--) {

        Student studentJ = dataget(j);

        String valueJ = studentJgetNum();

        if (valueJindexOf(key) >= 0)

          break;

      }

      Student temp = dataget(j + 1);

      dataset(j + 1, studentI);

      dataset(i, temp);

      searchHitRowsadd(IntegervalueOf(j + 1));

    }

    fireTableDataChanged();

  }

  public void setData(List<Student> data) {

    if (data == null)

      throw new IllegalArgumentException("参数data不能为null。");

    thisdata = data;

    fireTableDataChanged();

  }

  public int getHitRowCount() {

    return searchHitRowssize();

  }

}

从数据库查询出记录后,转成Student对象列表调用TestTableModel的setData设置表格的数据。

站内和网络检索区别:

1、数据库检索一般都会给网站一段代码,嵌入到网站中,就可以不用打开他们的检索页面。

2、而计算机检索,只是检索站内发布的资源,互联网上的其他站点的信息是不会被检索到的。

以上就是关于SQL 查找两表中不同的数据全部的内容,包括:SQL 查找两表中不同的数据、SQL查找某一字段相同,某一字段不同的数据、java中JTable 通过检索搜索出某行的其中一个数据 将该行置顶并改变颜色 连数据库多列数据咋办等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10154850.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存