3

我在我的 DB 3 col 中有一个值,我想在所有这些值中找到一个值,如下所述:表名:MyTable

-----------------------------
--id-- col1-- col2-- col3-
-----------------------------
   1     200    300     400 
   2     100    150     300
   3     800    102     20
   4     80     80       0

我希望 col1 col2 col3 的结果为 = 0 ,这是其中的最小值。可能吗 !!!!

我的尝试:

select Min(col1, col2 , col3) as Tablemin
from MyTable
4

4 回答 4

6

ANSI SQL:

select min(col)
from
(
    select col1 [col] from MyTable
    union all
    select col2 from MyTable
    union all
    select col3 from MyTable
)t
于 2011-07-16T11:53:42.497 回答
2

显示最小值的简单方法是:

string val = textBox2.Text;
DataSet ds;
con.Open();
string str = "SELECT * FROM Add_Rooms WHERE Price >= @price";
cmd = new SqlCommand(str, con);
cmd.Parameters.AddWithValue("@price", val);
SqlDataAdapter da = new SqlDataAdapter(cmd);
ds = new DataSet();
da.Fill(ds, "Add_Rooms");
dataGridView1.DataSource = ds;
dataGridView1.DataMember = "Add_Rooms";
con.Close(); 
于 2012-11-26T08:23:54.223 回答
2

如果是 MySQL 或 Oracle,则有LEAST()功能:

SELECT LEAST(MIN(col1), MIN(col2), MIN(col3))
       AS MinOfAllColumns
FROM MyTable

然后,CASE可以在大多数 RDBMS 中使用以下语句:

SELECT CASE WHEN MIN(col1) <= MIN(col2) AND MIN(col1) <= MIN(col3) 
                THEN MIN(col1)
            WHEN MIN(col2) <= MIN(col3)
                THEN MIN(col2)
                ELSE MIN(col3)            
       END 
       AS MinOfAllColumns
FROM MyTable

这也可以工作,但很难用这种UNION方法获得其他领域:

SELECT MIN(col) AS MinOfAllColumns
FROM 
  ( SELECT MIN(col1) AS col
    FROM MyTable
  UNION
    SELECT MIN(col2)
    FROM MyTable
  UNION
    SELECT MIN(col3)
    FROM MyTable
  ) AS tmp
于 2011-07-16T11:53:06.007 回答
1

在 SQLITE 中,答案很简单:

SELECT MIN(MIN(col1), MIN(col2), MIN(col3)) FROM MyTable;
于 2011-07-16T11:56:23.163 回答