Skip to content
Advertisement

How to order by use in codeigniter

My table data is like that

ID NAME order
1 English 0
2 Italian 1
3 Spanish 2
4 Hindi 1
5 Bengali 3
6 Tamil 2

my query

    $this->db->select('*');
    $this->db->from('languages');
    $this->db->order_by('order','asc');
    $query = $this->db->get();

I want data like this order-1,1,2,2,3,0

ID NAME order
2 Italian 1
4 Hindi 1
3 Spanish 2
6 Tamil 2
5 Bengali 3
1 English 0

Advertisement

Answer

Try this:

create table order_1(
id int(4),
name varchar(20),
`order` int(3) );

insert into order_1 values (1,'English',0), (2,'Italian',1), (3,'Spanish',2),(4,'Hindi',1),(5,'Bengali',3),(6,'Tamil',2);


SELECT * FROM order_1 ORDER BY `order`= 0, `order`;

enter image description here

User contributions licensed under: CC BY-SA
8 People found this is helpful
Advertisement