কম্পিউটার

MySQL এর সাথে সীমার পরে আরেকটি অর্ডার পান?


আপনাকে সিলেক্ট স্টেটমেন্ট সহ সাবকোয়েরি ব্যবহার করতে হবে, একটি ভিতরের জন্য এবং একটি বাইরের জন্য নির্বাচন করুন৷ অভ্যন্তরীণ নির্বাচন সারি প্রদান করবে এবং বাইরেরটি ক্রমবর্ধমান ক্রমে ক্রম করবে। সিনট্যাক্স নিম্নরূপ:

SELECT *FROM
(
   SELECT *FROM yourTableName ORDER BY yourColumnName1 DESC LIMIT 9
) AS anyAliasName
ORDER BY yourColumnName2;

উপরের সিনট্যাক্স বুঝতে, আসুন একটি টেবিল তৈরি করি। একটি টেবিল তৈরি করার প্রশ্নটি নিম্নরূপ:

mysql> create table OrderByAfterLimit
   -> (
   -> Id int NOT NULL AUTO_INCREMENT,
   -> UserName varchar(20),
   -> UserAge int,
   -> PRIMARY KEY(Id)
   -> );
Query OK, 0 rows affected (0.69 sec)

এখন আপনি insert কমান্ড ব্যবহার করে টেবিলে কিছু রেকর্ড সন্নিবেশ করতে পারেন। প্রশ্নটি নিম্নরূপ:

mysql> insert into OrderByAfterLimit(UserName, UserAge) values('John',23);
Query OK, 1 row affected (0.24 sec)
mysql> insert into OrderByAfterLimit(UserName, UserAge) values('Larry',21);
Query OK, 1 row affected (0.36 sec)
mysql> insert into OrderByAfterLimit(UserName, UserAge) values('Bob',26);
Query OK, 1 row affected (0.19 sec)
mysql> insert into OrderByAfterLimit(UserName, UserAge) values('James',22);
Query OK, 1 row affected (0.18 sec)
mysql> insert into OrderByAfterLimit(UserName, UserAge) values('Robert',28);
Query OK, 1 row affected (0.20 sec)
mysql> insert into OrderByAfterLimit(UserName, UserAge) values('Mike',29);
Query OK, 1 row affected (0.19 sec)
mysql> insert into OrderByAfterLimit(UserName, UserAge) values('Carol',24);
Query OK, 1 row affected (0.13 sec)
mysql> insert into OrderByAfterLimit(UserName, UserAge) values('David',20);
Query OK, 1 row affected (0.23 sec)
mysql> insert into OrderByAfterLimit(UserName, UserAge) values('Maxwell',30);
Query OK, 1 row affected (0.46 sec)

সিলেক্ট স্টেটমেন্ট ব্যবহার করে টেবিল থেকে সমস্ত রেকর্ড প্রদর্শন করুন। প্রশ্নটি নিম্নরূপ:

mysql> select *from OrderByAfterLimit;

নিম্নলিখিত আউটপুট:

+----+----------+---------+
| Id | UserName | UserAge |
+----+----------+---------+
|  1 | John     |      23 |
|  2 | Larry    |      21 |
|  3 | Bob      |      26 |
|  4 | James    |      22 |
|  5 | Robert   |      28 |
|  6 | Mike     |      29 |
|  7 | Carol    |      24 |
|  8 | David    |      20 |
|  9 | Maxwell  |      30 |
+----+----------+---------+
9 rows in set (0.00 sec)

সীমার পরে অর্ডার করার জন্য এখানে ক্যোয়ারী রয়েছে:

mysql> select *from
   -> (
   -> select *from OrderByAfterLimit order by UserAge DESC LIMIT 9) AS tbl1
   -> order by UserName;

নিম্নলিখিত আউটপুট:

+----+----------+---------+
| Id | UserName | UserAge |
+----+----------+---------+
|  3 | Bob      |      26 |
|  7 | Carol    |      24 |
|  8 | David    |      20 |
|  4 | James    |      22 |
|  1 | John     |      23 |
|  2 | Larry    |      21 |
|  9 | Maxwell  |      30 |
|  6 | Mike     |      29 |
|  5 | Robert   |      28 |
+----+----------+---------+
9 rows in set (0.00 sec)

  1. কিভাবে MySQL-এ শর্ত সহ ক্যোয়ারী অর্ডার এবং নির্বাচন করবেন?

  2. "অর্ডার" নামের একটি টেবিলের সাথে MySQL ক্যোয়ারী ত্রুটি?

  3. MySQL ORDER BY সংখ্যাসূচক ব্যবহারকারী-সংজ্ঞায়িত পরিবর্তনশীল দিয়ে?

  4. সংখ্যা সহ একটি VARCHAR স্ট্রিংয়ে হাইফেনের পরে সংখ্যাগুলি সরাতে MySQL ক্যোয়ারী