Bitwise AND operator


1. Get Active Categories

SQL Server Query 1

            
-- Bit 1: 1 = Active, 0 = Inactive  
-- Bit 2: 1 = Seasonal, 0 = Non-seasonal
-- Bit 3: 1 = Featured, 0 = Not featured
-- 1. Get Active Categories
SELECT Categories.CategoryID, Categories.CategoryName
FROM Categories, (VALUES
(1, 3), -- 1 = CategoryID, 3 = BitFlag: Active and Seasonal (1 | 2 = 3)
(2, 5), -- 2 = CategoryID, 5 = BitFlag: Active and Featured (1 | 4 = 5)
(3, 0) -- 3 = CategoryID, 0 = BitFlag: Inactive and Nonseasonal and Not Feature
) AS CategoryFeature (CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID AND
(CategoryFeature.BitFlag & 1) = 1; -- Bitwise AND with 1 (0001)

Create SQL query with SqlQueryBuilder 1

            
var (sql1, parameters1) = new SqlQueryBuilder()  
.Select()
.Columns("Categories.CategoryID", "Categories.CategoryName")
.From(new Table("Categories"), new VALUES(new List<List<object>>()
{
new List<object>() {1, 3 },
new List<object>() {2, 5 },
new List<object>() {3, 0 },
}, "CategoryFeature", "CategoryID", "BitFlag"))
.Where(new Where(new Column("Categories.CategoryID").Equale(new Column("CategoryFeature.CategoryID")))
.AND(new ColumnArithmatic().StartBracket("CategoryFeature.BitFlag").BitwiseAND(1).EndBracket().Equale(1))
)
.Build();

Query build by SqlQueryBuilder 1

            
SELECT Categories.CategoryID,
       Categories.CategoryName
FROM Categories, (VALUES (@pMAIN_2606210056348546910, @pMAIN_2606210056348546911), (@pMAIN_2606210056348546912, @pMAIN_2606210056348546913), (@pMAIN_2606210056348546914, @pMAIN_2606210056348546915)) AS CategoryFeature(CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID
      AND (CategoryFeature.BitFlag & @pMAIN_2606210056348546916) = @pMAIN_2606210056348546917;


            
        

Parameters (If used)

Name Value
@pMAIN_2606210056348546910 1
@pMAIN_2606210056348546911 3
@pMAIN_2606210056348546912 2
@pMAIN_2606210056348546913 5
@pMAIN_2606210056348546914 3
@pMAIN_2606210056348546915 0
@pMAIN_2606210056348546916 1
@pMAIN_2606210056348546917 1

Query Results 1:

  CategoryID CategoryName
1 1 Beverages
2 2 Condiments


2. Get Seasonal Categories

SQL Server Query 2

            
-- Bit 1: 1 = Active, 0 = Inactive  
-- Bit 2: 1 = Seasonal, 0 = Non-seasonal
-- Bit 3: 1 = Featured, 0 = Not featured
-- 2. Get Seasonal Categories
SELECT Categories.CategoryID, Categories.CategoryName
FROM Categories, (VALUES
(1, 3), -- 1 = CategoryID, 3 = BitFlag: Active and Seasonal (1 | 2 = 3)
(2, 5), -- 2 = CategoryID, 5 = BitFlag: Active and Featured (1 | 4 = 5)
(3, 0) -- 3 = CategoryID, 0 = BitFlag: Inactive and Nonseasonal and Not Feature
) AS CategoryFeature (CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID AND (CategoryFeature.BitFlag & 2) = 2; -- Bitwise AND with 2 (0010)

Create SQL query with SqlQueryBuilder 2

            
var (sql2, parameters2) = new SqlQueryBuilder()  
.Select()
.Columns("Categories.CategoryID", "Categories.CategoryName")
.From(new Table("Categories"), new VALUES(new List<List<object>>()
{
new List<object>() {1, 3 },
new List<object>() {2, 5 },
new List<object>() {3, 0 },
}, "CategoryFeature", "CategoryID", "BitFlag"))
.Where(new Where(new Column("Categories.CategoryID").Equale(new Column("CategoryFeature.CategoryID")))
.AND(new ColumnArithmatic().StartBracket("CategoryFeature.BitFlag").BitwiseAND(2).EndBracket().Equale(2))
)
.Build();

Query build by SqlQueryBuilder 2

            
SELECT Categories.CategoryID,
       Categories.CategoryName
FROM Categories, (VALUES (@pMAIN_2606210056348711830, @pMAIN_2606210056348711831), (@pMAIN_2606210056348711832, @pMAIN_2606210056348711833), (@pMAIN_2606210056348711834, @pMAIN_2606210056348711835)) AS CategoryFeature(CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID
      AND (CategoryFeature.BitFlag & @pMAIN_2606210056348711836) = @pMAIN_2606210056348711837;


            
        

Parameters (If used)

Name Value
@pMAIN_2606210056348711830 1
@pMAIN_2606210056348711831 3
@pMAIN_2606210056348711832 2
@pMAIN_2606210056348711833 5
@pMAIN_2606210056348711834 3
@pMAIN_2606210056348711835 0
@pMAIN_2606210056348711836 2
@pMAIN_2606210056348711837 2

Query Results 2:

  CategoryID CategoryName
1 1 Beverages


3. Get Featured Categories

SQL Server Query 3

            
-- Bit 1: 1 = Active, 0 = Inactive  
-- Bit 2: 1 = Seasonal, 0 = Non-seasonal
-- Bit 3: 1 = Featured, 0 = Not featured
-- 3. Get Featured Categories
SELECT Categories.CategoryID, Categories.CategoryName
FROM Categories, (VALUES
(1, 3), -- 1 = CategoryID, 3 = BitFlag: Active and Seasonal (1 | 2 = 3)
(2, 5), -- 2 = CategoryID, 5 = BitFlag: Active and Featured (1 | 4 = 5)
(3, 0) -- 3 = CategoryID, 0 = BitFlag: Inactive and Nonseasonal and Not Feature
) AS CategoryFeature (CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID AND (CategoryFeature.BitFlag & 4) = 4; -- Bitwise AND with 4 (0100)

Create SQL query with SqlQueryBuilder 3

            
var (sql3, parameters3) = new SqlQueryBuilder()  
.Select()
.Columns("Categories.CategoryID", "Categories.CategoryName")
.From(new Table("Categories"), new VALUES(new List<List<object>>()
{
new List<object>() {1, 3 },
new List<object>() {2, 5 },
new List<object>() {3, 0 },
}, "CategoryFeature", "CategoryID", "BitFlag"))
.Where(new Where(new Column("Categories.CategoryID").Equale(new Column("CategoryFeature.CategoryID")))
.AND(new ColumnArithmatic().StartBracket("CategoryFeature.BitFlag").BitwiseAND(4).EndBracket().Equale(4))
)
.Build();

Query build by SqlQueryBuilder 3

            
SELECT Categories.CategoryID,
       Categories.CategoryName
FROM Categories, (VALUES (@pMAIN_2606210056348774300, @pMAIN_2606210056348774301), (@pMAIN_2606210056348774302, @pMAIN_2606210056348774303), (@pMAIN_2606210056348774304, @pMAIN_2606210056348774305)) AS CategoryFeature(CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID
      AND (CategoryFeature.BitFlag & @pMAIN_2606210056348774306) = @pMAIN_2606210056348774307;


            
        

Parameters (If used)

Name Value
@pMAIN_2606210056348774300 1
@pMAIN_2606210056348774301 3
@pMAIN_2606210056348774302 2
@pMAIN_2606210056348774303 5
@pMAIN_2606210056348774304 3
@pMAIN_2606210056348774305 0
@pMAIN_2606210056348774306 4
@pMAIN_2606210056348774307 4

Query Results 3:

  CategoryID CategoryName
1 2 Condiments


4. Get Categories that are either Active or Featured

SQL Server Query 4

            
-- Bit 1: 1 = Active, 0 = Inactive  
-- Bit 2: 1 = Seasonal, 0 = Non-seasonal
-- Bit 3: 1 = Featured, 0 = Not featured
-- 3. Get Featured Categories
SELECT Categories.CategoryID, Categories.CategoryName
FROM Categories, (VALUES
(1, 3), -- 1 = CategoryID, 3 = BitFlag: Active and Seasonal (1 | 2 = 3)
(2, 5), -- 2 = CategoryID, 5 = BitFlag: Active and Featured (1 | 4 = 5)
(3, 0) -- 3 = CategoryID, 0 = BitFlag: Inactive and Nonseasonal and Not Feature
) AS CategoryFeature (CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID AND (CategoryFeature.BitFlag & (1 | 4 )) > 0; -- Bitwise AND with (1 OR 4) = 5 (0101)

Create SQL query with SqlQueryBuilder 4

            
var (sql4, parameters4) = new SqlQueryBuilder()  
.Select()
.Columns("Categories.CategoryID", "Categories.CategoryName")
.From(new Table("Categories"), new VALUES(new List<List<object>>()
{
new List<object>() {1, 3 },
new List<object>() {2, 5 },
new List<object>() {3, 0 },
}, "CategoryFeature", "CategoryID", "BitFlag"))
.Where(new Where(new Column("Categories.CategoryID").Equale(new Column("CategoryFeature.CategoryID")))
.AND(new ColumnArithmatic().StartBracket("CategoryFeature.BitFlag").BitwiseAND()
.StartBracket().Value(1).BitwiseOR(4).EndBracket()
.EndBracket().GreaterThan(0))
)
.Build();

Query build by SqlQueryBuilder 4

            
SELECT Categories.CategoryID,
       Categories.CategoryName
FROM Categories, (VALUES (@pMAIN_2606210056348815020, @pMAIN_2606210056348815021), (@pMAIN_2606210056348815022, @pMAIN_2606210056348815023), (@pMAIN_2606210056348815024, @pMAIN_2606210056348815025)) AS CategoryFeature(CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID
      AND (CategoryFeature.BitFlag & (@pMAIN_2606210056348815026 | @pMAIN_2606210056348815027)) > @pMAIN_2606210056348815028;


            
        

Parameters (If used)

Name Value
@pMAIN_2606210056348815020 1
@pMAIN_2606210056348815021 3
@pMAIN_2606210056348815022 2
@pMAIN_2606210056348815023 5
@pMAIN_2606210056348815024 3
@pMAIN_2606210056348815025 0
@pMAIN_2606210056348815026 1
@pMAIN_2606210056348815027 4
@pMAIN_2606210056348815028 0

Query Results 4:

  CategoryID CategoryName
1 1 Beverages
2 2 Condiments


5. Get Categories that are Active AND Seasonal

SQL Server Query 5

            
-- Bit 1: 1 = Active, 0 = Inactive  
-- Bit 2: 1 = Seasonal, 0 = Non-seasonal
-- Bit 3: 1 = Featured, 0 = Not featured
-- 3. Get Featured Categories
SELECT Categories.CategoryID, Categories.CategoryName
FROM Categories, (VALUES
(1, 3), -- 1 = CategoryID, 3 = BitFlag: Active and Seasonal (1 | 2 = 3)
(2, 5), -- 2 = CategoryID, 5 = BitFlag: Active and Featured (1 | 4 = 5)
(3, 0) -- 3 = CategoryID, 0 = BitFlag: Inactive and Nonseasonal and Not Feature
) AS CategoryFeature (CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID AND (CategoryFeature.BitFlag & (1 | 2 )) = (1 | 2);

Create SQL query with SqlQueryBuilder 5

            
var (sql5, parameters5) = new SqlQueryBuilder()  
.Select()
.Columns("Categories.CategoryID", "Categories.CategoryName")
.From(new Table("Categories"), new VALUES(new List<List<object>>()
{
new List<object>() {1, 3 },
new List<object>() {2, 5 },
new List<object>() {3, 0 },
}, "CategoryFeature", "CategoryID", "BitFlag"))
.Where(new Where(new Column("Categories.CategoryID").Equale(new Column("CategoryFeature.CategoryID")))
.AND(new ColumnArithmatic().StartBracket("CategoryFeature.BitFlag").BitwiseAND()
.StartBracket().Value(1).BitwiseOR(2).EndBracket()
.EndBracket().Equale(new ColumnArithmatic().StartBracket().Value(1).BitwiseOR(2).EndBracket()))
)
.Build();

Query build by SqlQueryBuilder 5

            
SELECT Categories.CategoryID,
       Categories.CategoryName
FROM Categories, (VALUES (@pMAIN_2606210056348868060, @pMAIN_2606210056348868061), (@pMAIN_2606210056348868062, @pMAIN_2606210056348868063), (@pMAIN_2606210056348868064, @pMAIN_2606210056348868065)) AS CategoryFeature(CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID
      AND (CategoryFeature.BitFlag & (@pMAIN_2606210056348868066 | @pMAIN_2606210056348868067)) = (@pMAIN_2606210056348868068 | @pMAIN_2606210056348868069);


            
        

Parameters (If used)

Name Value
@pMAIN_2606210056348868060 1
@pMAIN_2606210056348868061 3
@pMAIN_2606210056348868062 2
@pMAIN_2606210056348868063 5
@pMAIN_2606210056348868064 3
@pMAIN_2606210056348868065 0
@pMAIN_2606210056348868066 1
@pMAIN_2606210056348868067 2
@pMAIN_2606210056348868068 1
@pMAIN_2606210056348868069 2

Query Results 5:

  CategoryID CategoryName
1 1 Beverages


6. Get Inactive Categories

SQL Server Query 6

            
-- Bit 1: 1 = Active, 0 = Inactive  
-- Bit 2: 1 = Seasonal, 0 = Non-seasonal
-- Bit 3: 1 = Featured, 0 = Not featured
-- 3. Get Featured Categories
SELECT Categories.CategoryID, Categories.CategoryName
FROM Categories, (VALUES
(1, 3), -- 1 = CategoryID, 3 = BitFlag: Active and Seasonal (1 | 2 = 3)
(2, 5), -- 2 = CategoryID, 5 = BitFlag: Active and Featured (1 | 4 = 5)
(3, 0) -- 3 = CategoryID, 0 = BitFlag: Inactive and Nonseasonal and Not Feature
) AS CategoryFeature (CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID AND (CategoryFeature.BitFlag & 1) = 0;

Create SQL query with SqlQueryBuilder 6

            
var (sql6, parameters6) = new SqlQueryBuilder()  
.Select()
.Columns("Categories.CategoryID", "Categories.CategoryName")
.From(new Table("Categories"), new VALUES(new List<List<object>>()
{
new List<object>() {1, 3 },
new List<object>() {2, 5 },
new List<object>() {3, 0 },
}, "CategoryFeature", "CategoryID", "BitFlag"))
.Where(new Where(new Column("Categories.CategoryID").Equale(new Column("CategoryFeature.CategoryID")))
.AND(new ColumnArithmatic().StartBracket("CategoryFeature.BitFlag").BitwiseAND(1)
.EndBracket().Equale(0))
)
.Build();

Query build by SqlQueryBuilder 6

            
SELECT Categories.CategoryID,
       Categories.CategoryName
FROM Categories, (VALUES (@pMAIN_2606210056348916060, @pMAIN_2606210056348916061), (@pMAIN_2606210056348916062, @pMAIN_2606210056348916063), (@pMAIN_2606210056348916064, @pMAIN_2606210056348916065)) AS CategoryFeature(CategoryID, BitFlag)
WHERE Categories.CategoryID = CategoryFeature.CategoryID
      AND (CategoryFeature.BitFlag & @pMAIN_2606210056348916066) = @pMAIN_2606210056348916067;


            
        

Parameters (If used)

Name Value
@pMAIN_2606210056348916060 1
@pMAIN_2606210056348916061 3
@pMAIN_2606210056348916062 2
@pMAIN_2606210056348916063 5
@pMAIN_2606210056348916064 3
@pMAIN_2606210056348916065 0
@pMAIN_2606210056348916066 1
@pMAIN_2606210056348916067 0

Query Results 6:

  CategoryID CategoryName
1 3 Confections