비교 연산자에는 =, "", "=", >, "IS NULL", "IS NOT NULL", LEAST, GREATEST, IN, ""NOT IN", LIKE, REGEXP 등
이 튜토리얼의 운영 환경: windows7 시스템, mysql8 버전, Dell G3 컴퓨터
비교 연산자. 오늘은 MySQL 비교연산자에 대한 자세한 설명을 포스팅해보겠습니다. 예를 들어 = 연산자는 표현식의 양쪽이 같은지 비교합니다.
연산자는 표현식의 양쪽이 같지 않은지 테스트하여 참값을 반환합니다.
비교 연산자
비교 연산자의 결과는 항상 1,0 또는 NULL입니다. MySQL의 비교 연산자는
=, , =, >, IS NULL, LEAST, GREATEST, BETWEEN . , ISNULL, IN, LIKE, REGEXP
SELECT 1=0, '2'=2, 2=2,'0.02'=0, 'b'='b', (1+3) = (2+2),NULL=NULL;
동등 판단을 위해 '<=>'를 사용하면, SQL문은 다음과 같습니다.
결과를 보면 '< = >'는 비교 연산을 수행할 때 '='와 유사한 기능을 갖습니다. 유일한 차이점은 '<=>'를 사용하여 둘 다 NULL인 경우 반환 값이 1이라는 것입니다. <> 또는 !=
'<>' 또는 '!='는 숫자, 문자열 또는 표현식이 동일하지 않은지 여부를 판단하는 데 사용됩니다. 반환 값은 1입니다. 값은 0입니다. 이 두 연산자는 null 값 NULL을 판단하는 데 사용할 수 없습니다.
'<>' 및 '!='를 사용하여 불일치를 판단합니다.
SELECT 'good'<>'god', 1<>2, 4!=4, 5.5!=5, (1+3)!=(2+1),NULL<>NULL;
비교 및 판단에는 '<='를 사용합니다. 명령문은 다음과 같습니다:
SELECT 'good'<='god', 1<=2, 4<=4, 5.5<=5, (1+3) <= (2+1),NULL<=NULL;
'<'를 사용하여 비교하고 판단하세요.
SELECT 'good'<'god', 1<2, 4<4, 5.5<5, (1+3) < (2+1),NULL<NULL;
SELECT 'good'>='god', 1>=2, 4>=4, 5.5>=5, (1+3) >= (2+1),NULL>=NULL;
사용하세요. 비교 및 판단을 위한 '>' SQL 문은 다음과 같습니다.
SELECT 'good'>'god', 1>2, 4>4, 5.5>5, (1+3) > (2+1),NULL>NULL;
NULL 및 NULL이 아닌 값을 판단하려면 IS NULL, ISNULL 및 IS NOT NULL을 사용하세요.
SELECT NULL IS NULL, ISNULL(NULL),ISNULL(10), 10 IS NOT NULL;
BETWEEN AND를 사용하여 다음과 같이 SQL 문을 입력합니다.
SELECT 4 BETWEEN 4 AND 6, 4 BETWEEN 4 AND 6,12 BETWEEN 9 AND 10;
SELECT 'x' BETWEEN 'f' AND 'g', 'b' BETWEEN 'a' AND 'c';
LEAST 연산자를 사용하여 크기를 결정합니다.
SELECT least(2,0), least(20.0,3.0,100.5), least('a','c','b'),least(10,NULL);
使用GREATEST运算符进行大小判断,SQL语句如下:
SELECT greatest(2,0), greatest(20.0,3.0,100.5), greatest('a','c','b'),greatest(10,NULL);
使用IN、NOT IN运算符进行判断,SQL语句如下:
SELECT 2 IN (1,3,5,'thks'), 'thks' IN (1,3,5,'thks');
存在NULL值时的IN查询,SQL语句如下:
SELECT NULL IN (1,3,5,'thks'),10 IN (1,3,NULL,'thks');
使用运算符LIKE进行字符串匹配运算,SQL语句如下:
SELECT 'stud' LIKE 'stud', 'stud' LIKE 'stu_','stud' LIKE '%d','stud' LIKE 't_ _ _', 's' LIKE NULL;
使用运算符REGEXP进行字符串匹配运算,SQL语句如下:
SELECT 'ssky' REGEXP '^s', 'ssky' REGEXP 'y$', 'ssky' REGEXP '.sky', 'ssky' REGEXP '[ab]';
扩展资料:
逻辑运算符
逻辑运算符的求值所得结果均为TRUE、FALSE或NULL。
逻辑运算符有:
NOT 或者 !
AND 或者 &&
OR 或者 ||
XOR(异或)
使用非运算符“NOT”和“!”进行逻辑判断,SQL语句如下:
SELECT NOT 10, NOT (1-1), NOT -5, NOT NULL, NOT 1 + 1;
SELECT !10, !(1-1), !-5, ! NULL, ! 1 + 1;
使用与运算符“AND”和“&&”进行逻辑判断,SQL语句如下:
SELECT 1 AND -1,1 AND 0,1 AND NULL, 0 AND NULL;
SELECT 1 && -1,1 && 0,1 && NULL, 0 && NULL;
使用或运算符“OR”和“||”进行逻辑判断,SQL语句如下:
SELECT 1 OR -1 OR 0, 1 OR 2,1 OR NULL, 0 OR NULL, NULL OR NULL;
SELECT 1 || -1 || 0, 1 || 2,1 || NULL, 0 || NULL, NULL || NULL;
使用异或运算符“XOR”进行逻辑判断,SQL语句如下:
SELECT 1 XOR 1, 0 XOR 0, 1 XOR 0, 1 XOR NULL, 1 XOR 1 XOR 1;
执行上面的语句,结果如下。
位运算符
位运算符是用来对二进制字节中的位进行测试、移位或者测试处理。位运算符有:
位或(|)
位与(&)
位异或(^ )
位左移(<<)
位右移(<<)
位取反(~)
使用位或运算符进行运算,SQL语句如下:
SELECT 10 | 15, 9 | 4 | 2;
使用位与运算符进行运算,SQL语句如下:
SELECT 10 & 15, 9 &4& 2;
使用位异或运算符进行运算,SQL语句如下:
SELECT 10 ^ 15, 1 ^0, 1 ^ 1;
使用位左移运算符进行运算,SQL语句如下:
SELECT 1<<2, 4<<2;
使用位右移运算符进行运算,SQL语句如下:
SELECT 1>>1, 16>>2;
使用位取反运算符进行运算,SQL语句如下:
SELECT 5 & ~1;
运算符的优先级
运算的优先级决定了不同的运算符在表达式中计算的先后顺序。
级别高的运算符先进行计算,如果级别相同,MySQL按表达式的顺序从左到右依次计算。当然,在无法确定优先级的情况下,可以使用圆括号“()”来改变优先级。
默认情况下,MySQL相关论文,对不区是区分大小写的。如果你需要区分,你需要添加二进制关键字。
=,运算符用于比较表达式的左侧是否小于或等于、大于或等于、小于或大于右侧。
between运算符用于检测某个值是否存在于指定范围内。其中它返回真实值。
您可以添加一个非逻辑运算符来否定between比较,只有当表达式在给定范围之外时,才会返回真值。
in运算符用于验证一个值是否包含在一组指定的值中。其中返回真实值。
为空和非空运算符用于执行包含空值的比较操作
运算符称为空安全等号
相似运算符的通配符。
当使用包含like运算符的查询时,建议确保对where子句中命中的列进行索引,并且where子句包含足够的数据来限制开头搜索的记录数。
相关推荐:《mysql教程》
위 내용은 비교 연산자는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!