1

我正在尝试使用该表的主键从数据库中获取数据。问题是每个表的主键名称会不同。

例如,用户可能想要拉起员工表,主键是 Emp_ID。然后他们想调出制造商表,主键是 Manu_ID。

由于信息是在同一个 ViewModel 中提取的,所以一切都需要是动态的。

这是查看制造商表的 SQL 语句:

C#:

string strSQLconnection = (connectionString);
SqlConnection sqlConnection = new SqlConnection(strSQLconnection);

tableName = tableName + "AuditLogView";

sqlConnection.Open();
SqlCommand sqlCommand = new SqlCommand("SELECT *  FROM @tableName WHERE ManufacturersID = @primarykey", sqlConnection);
sqlCommand.Parameters.AddWithValue("@tablename", tableName);
sqlCommand.Parameters.AddWithValue("@primarykey", primaryKeyID);

SqlDataReader reader = sqlCommand.ExecuteReader();

其中一些已经动态实现,例如来自用户的主键和表名。我想如果我总能在我的表中找到主键,那么它应该可以工作。有没有办法做到这一点?我正在使用 SQL Server 2008 R2。任何帮助表示赞赏。

4

2 回答 2

0

此查询将获得 pkey 列名称:

SELECT 
    cu.CONSTRAINT_NAME, 
    cu.COLUMN_NAME 
FROM 
    INFORMATION_SCHEMA.KEY_COLUMN_USAGE cu 
WHERE 
    EXISTS 
        (
            SELECT tc.* 
            FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS tc 
            WHERE 
                tc.CONSTRAINT_CATALOG = 'dbName' 
                AND tc.TABLE_NAME = 'tableName' 
                AND tc.CONSTRAINT_TYPE = 'PRIMARY KEY' 
                AND tc.CONSTRAINT_NAME = cu.CONSTRAINT_NAME 
        )
于 2013-03-13T13:55:06.010 回答
0

那么,您想创建一个接受表名和列名作为参数的通用查询吗?

尝试这个:

首先,创建一个存储过程,这个存储过程会根据参数创建通用查询。

-- @tabName = table name
-- @colName = column name
-- @colVal = column value
create proc p1 @tabName varchar(100), @colName varchar(100), @colVal varchar(100)
as
begin
    declare @sql nvarchar(max) = N'select * from ' + @tabName + ' where ' + @colName + ' = ''' + @colVal + ''''
    exec sp_executesql @sql 
end

然后,从您的代码中调用该存储过程:

string strSQLconnection = (connectionString);
SqlConnection sqlConnection = new SqlConnection(strSQLconnection);
sqlConnection.Open();
SqlCommand sqlCommand = new SqlCommand("p1", sqlConnection);
sqlCommand.CommandType = CommandType.StoredProcedure;
sqlCommand.Parameters.AddWithValue("@tabName", "table1");
sqlCommand.Parameters.AddWithValue("@colName", "col1");
sqlCommand.Parameters.AddWithValue("@colVal", "1");        

SqlDataReader reader = sqlCommand.ExecuteReader();


sqlConnection.Close();
于 2013-03-13T14:03:36.023 回答