একটি একক প্রশ্নের মধ্যে বুলিয়ান ক্ষেত্রের মান গণনা করতে, আপনি CASE বিবৃতি ব্যবহার করতে পারেন। আমাদের উদাহরণের জন্য একটি ডেমো টেবিল তৈরি করা যাক -
mysql> create table countBooleanFieldDemo -> ( -> StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY, -> StudentFirstName varchar(20), -> isPassed tinyint(1) -> ); Query OK, 0 rows affected (0.63 sec)
সন্নিবেশ কমান্ড ব্যবহার করে টেবিলে কিছু রেকর্ড সন্নিবেশ করান।
প্রশ্নটি নিম্নরূপ -
mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('Larry',0); Query OK, 1 row affected (0.12 sec) mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('Mike',1); Query OK, 1 row affected (0.17 sec) mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('Sam',0); Query OK, 1 row affected (0.21 sec) mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('Carol',1); Query OK, 1 row affected (0.15 sec) mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('Bob',1); Query OK, 1 row affected (0.16 sec) mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('David',1); Query OK, 1 row affected (0.13 sec) mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('Ramit',0); Query OK, 1 row affected (0.28 sec) mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('Chris',1); Query OK, 1 row affected (0.20 sec) mysql> insert into countBooleanFieldDemo(StudentFirstName,isPassed) values('Robert',1); Query OK, 1 row affected (0.16 sec)
সিলেক্ট স্টেটমেন্ট ব্যবহার করে টেবিল থেকে সমস্ত রেকর্ড প্রদর্শন করুন।
প্রশ্নটি নিম্নরূপ -
mysql> select *from countBooleanFieldDemo;
এখানে আউটপুট −
+-----------+------------------+----------+ | StudentId | StudentFirstName | isPassed | +-----------+------------------+----------+ | 1 | Larry | 0 | | 2 | Mike | 1 | | 3 | Sam | 0 | | 4 | Carol | 1 | | 5 | Bob | 1 | | 6 | David | 1 | | 7 | Ramit | 0 | | 8 | Chris | 1 | | 9 | Robert | 1 | +-----------+------------------+----------+ 9 rows in set (0.00 sec)
এখানে একটি ক্যোয়ারী −
-এর মধ্যে বুলিয়ান ফিল্ডের মান গণনা করার জন্য ক্যোয়ারী রয়েছেmysql> select sum(isPassed= 1) as `True`, sum(isPassed = 0) as `False`, -> ( -> case when sum(isPassed = 1) > 0 then sum(isPassed = 0) / sum(isPassed = 1) -> end -> )As TotalPercentage -> from countBooleanFieldDemo;
নিচের আউটপুট −
+------+-------+-----------------+ | True | False | TotalPercentage | +------+-------+-----------------+ | 6 | 3 | 0.5000 | +------+-------+-----------------+ 1 row in set (0.00 sec)