使用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 通过检索搜索出某行的其中一个数据 将该行置顶并改变颜色 连数据库多列数据咋办等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)