I have Deal model who has an attribute called 'info' with this structure:
Inside the column 'info' on Deal:
Deal1.info = [{"deal_id":"4","text1":"qqq","text2":"sqsq","image1":"sqqs","video1":"sqsq"},{"deal_id":"5","text1":"sqqs","text2":"qq"}]
# no image here inside the json
Deal2.info =
[{"deal_id":"4","text1":"qqq","video1":"sqsq"},{"deal_id":"5","text1":"sqqs","text2":"qq"}]
The column was defined in the mligration as json
add_column :deals, :info, :json, default: '[]'
How can I query this in jsonb with active record ?
find all the deals where infos contain at least one deal_id = 4
find all the deal where infos contain at lest a json block ({ }) with a key called 'image1' (it should only output Deal1 , and not deal2)