这是一个从表中选择所有记录的示例代码。有人能告诉我如何选择该表的最后一条记录吗?

select * from table

当我使用:选择*从表顺序由ID DESC限制 第1行:'LIMIT'附近的语法不正确。 这是我使用的代码:

private void LastRecord()
{
    SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["HELPDESK_OUTLOOKConnectionString3"].ToString());

    conn.Open();
    SqlDataReader myReader = null;
    SqlCommand myCommand = new SqlCommand("SELECT * FROM HD_AANVRAGEN ORDER BY " +
                "aanvraag_id DESC LIMIT 1", conn);
    myReader = myCommand.ExecuteReader();
    while (myReader.Read())
    {
        TextBox1.Text = (myReader["aanvraag_id"].ToString());
        TextBox1.Text += (myReader["wijziging_nummer"].ToString());
        TextBox1.Text += (myReader["melding_id"].ToString());
        TextBox1.Text += (myReader["aanvraag_titel"].ToString());
        TextBox1.Text += (myReader["aanvraag_omschrijving"].ToString());
        TextBox1.Text += (myReader["doorlooptijd_id"].ToString());
        TextBox1.Text += (myReader["rapporteren"].ToString());
        TextBox1.Text += (myReader["werknemer_id"].ToString());
        TextBox1.Text += (myReader["outlook_id"].ToString());
    }
}

当前回答

几乎所有的答案都假设ID列是有序的(可能是自动递增的)。但是,在某些情况下,ID列没有排序,因此ORDER BY语句没有意义。

最后插入的ID可能并不总是最高的ID,它只是最后一个(唯一的)条目。

对于这种情况,一个可能的解决方案是动态创建一个行id:

SET @r = 0;
SELECT * FROM (SELECT *, (@r := @r + 1) AS r_id FROM my_table) AS tmp
    ORDER BY r_id DESC LIMIT 1;

其他回答

你也可以这样做:

SELECT LAST (column_name) AS LAST_CUSTOMER FROM table_name

假设你有一个Id列:

SELECT TOP 1 *
  FROM table
 ORDER
    BY Id DESC;

同样,这也适用于SQL Server。我认为MySQL你可能需要使用:

SELECT *
  FROM table
 ORDER
    BY Id DESC
 LIMIT 1

但是,我不是百分之百确定。

EDIT

看看其他答案,我现在100%相信我是正确的MySQL语句:o)

EDIT

刚刚看到你最新的评论。你可以这样做:

SELECT MAX(Id)
  FROM table

这会让你得到最高的Id号。

我想这个就可以了。

declare @x int;
select @x = max(id) from table_name;
select * from where id = @x;

在Oracle中,你可以这样做:

SELECT *
FROM (SELECT EMP.*,ROWNUM FROM EMP ORDER BY ROWNUM DESC)
WHERE ROWNUM=1;

这是一种可能的方法。

SELECT * FROM TABLE ORDER BY ID DESC LIMIT 1

是的,这是mysql, SQL Server:

SELECT TOP 1 * FROM Table ORDER BY ID DESC