现在要查询出 男女人数相等的班级
SELECT S.CLASS from student s group by s.class HAVING COUNT(CASE WHEN S.SEX = 'F' THEN S.SEX END ) = COUNT(CASE WHEN S.SEX = 'M' THEN S.SEX END)
String、StringBuffer与StringBuilder之间区别
1.三者在执行速度方面的比较:StringBuilder > StringBuffer > String
4.StringBuilder:线程非安全的、StringBuffer:线程安全的。
当我们在字符串缓冲去被多个线程使用是,JVM不能保证StringBuilder的操作是安全的,虽然他的速度最快,但是可以保证StringBuffer是可以正确操作的。当然大多数情况下就是我们是在单线程下进行的操作,所以大多数情况下是建议用StringBuilder而不用StringBuffer的,就是速度的原因。
对于三者使用的总结:
1.如果要操作少量的数据用 = String
2.单线程操作字符串缓冲区 下操作大量数据 = StringBuilder
3.多线程操作字符串缓冲区 下操作大量数据 = StringBuffer
SELECT S.CLASS from student s group by s.class HAVING COUNT(CASE WHEN S.SEX = 'F' THEN S.SEX END ) = COUNT(CASE WHEN S.SEX = 'M' THEN S.SEX END)
String、StringBuffer与StringBuilder之间区别
1.三者在执行速度方面的比较:StringBuilder > StringBuffer > String
4.StringBuilder:线程非安全的、StringBuffer:线程安全的。
当我们在字符串缓冲去被多个线程使用是,JVM不能保证StringBuilder的操作是安全的,虽然他的速度最快,但是可以保证StringBuffer是可以正确操作的。当然大多数情况下就是我们是在单线程下进行的操作,所以大多数情况下是建议用StringBuilder而不用StringBuffer的,就是速度的原因。
对于三者使用的总结:
1.如果要操作少量的数据用 = String
2.单线程操作字符串缓冲区 下操作大量数据 = StringBuilder
3.多线程操作字符串缓冲区 下操作大量数据 = StringBuffer