Hi rakibxl,
You need to set RowVisibility property of your Table Row to hide the blank space.
For implement RDLC refer below article.
Database
For this example I have used of Northwind database that you can download using the link given below.
Download Northwind Database
Expression
=IIf(Fields!Country.Value="Mexico",True,False)
data:image/s3,"s3://crabby-images/4cc72/4cc722edb1faac1de19bfbc4df489598bed565e7" alt=""
In the below example i have placed two table.
In that first table i have set the TextBox visible property.
data:image/s3,"s3://crabby-images/abc62/abc6273f5955298e63594818b7210a69f63ee6b8" alt=""
In the 2nd i have set the Row Visibility.. property.
data:image/s3,"s3://crabby-images/45051/4505191ab0c2b61b2c5bb50162a9c62563969595" alt=""
Code
C#
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ReportViewer1.ProcessingMode = ProcessingMode.Local;
ReportViewer1.LocalReport.ReportPath = Server.MapPath("~/Report.rdlc");
Customers dsCustomers = GetData("select top 5 * from customers");
ReportDataSource datasource = new ReportDataSource("Customers", dsCustomers.Tables[0]);
ReportViewer1.LocalReport.DataSources.Clear();
ReportViewer1.LocalReport.DataSources.Add(datasource);
}
}
private Customers GetData(string query)
{
string conString = ConfigurationManager.ConnectionStrings["constr"].ConnectionString;
SqlCommand cmd = new SqlCommand(query);
using (SqlConnection con = new SqlConnection(conString))
{
using (SqlDataAdapter sda = new SqlDataAdapter())
{
cmd.Connection = con;
sda.SelectCommand = cmd;
using (Customers dsCustomers = new Customers())
{
sda.Fill(dsCustomers, "DataTable1");
return dsCustomers;
}
}
}
}
VB.Net
Protected Sub Page_Load(sender As Object, e As EventArgs) Handles Me.Load
If Not IsPostBack Then
ReportViewer1.ProcessingMode = ProcessingMode.Local
ReportViewer1.LocalReport.ReportPath = Server.MapPath("~/Report.rdlc")
Dim dsCustomers As Customers = GetData("select top 5 * from customers")
Dim datasource As New ReportDataSource("Customers", dsCustomers.Tables(0))
ReportViewer1.LocalReport.DataSources.Clear()
ReportViewer1.LocalReport.DataSources.Add(datasource)
End If
End Sub
Private Function GetData(query As String) As Customers
Dim conString As String = ConfigurationManager.ConnectionStrings("constr").ConnectionString
Dim cmd As New SqlCommand(query)
Using con As New SqlConnection(conString)
Using sda As New SqlDataAdapter()
cmd.Connection = con
sda.SelectCommand = cmd
Using dsCustomers As New Customers()
sda.Fill(dsCustomers, "DataTable1")
Return dsCustomers
End Using
End Using
End Using
End Function
Screenshot
data:image/s3,"s3://crabby-images/c67ea/c67ea7684c0580c2739e86ebfec66989092754c1" alt=""
In the screenshot you will see the left table has empty space where as in right table empty space removed.