SQLite資料庫中擷取新插入資料的自增長ID

來源:互聯網
上載者:User

標籤:

SQLite資料庫中有一有列名為ID的自增列,項目需求要在向資料庫在插入新資料的同時返回新插入資料行的ID。

我這裡用事務,把插入和查詢語句通過ExecuteReader一起提交。

實現代碼
public bool Insert(string topic, string key, string value, out int id){    DbProviderFactory factory = SQLiteFactory.Instance;    using (DbConnection conn = factory.CreateConnection())    {        conn.ConnectionString = _connectionString;        conn.Open();        DbCommand cmdInsert = conn.CreateCommand();        cmdInsert.Parameters.Add(cmdInsert.CreateParameter());        cmdInsert.Parameters.Add(cmdInsert.CreateParameter());        cmdInsert.Parameters.Add(cmdInsert.CreateParameter());        DbTransaction trans = conn.BeginTransaction();        try        {            cmdInsert.CommandText = "INSERT INTO [{0}] ([Topic],[Key],[Value]) VALUES (?,?,?);SELECT LAST_INSERT_ROWID() FROM [{0}]";            cmdInsert.CommandText = string.Format(cmdInsert.CommandText, _messageTableName);            cmdInsert.Parameters[0].Value = topic;            cmdInsert.Parameters[1].Value = key;            cmdInsert.Parameters[2].Value = value;            DbDataReader reader = cmdInsert.ExecuteReader();            trans.Commit();            if (reader.Read())            {                id = int.Parse(reader[0].ToString());                reader.Close();                return true;            }            else            {                SAEC_Log4net.Log.Error("insert message to db fail");                id = 0;                return false;            }        }        catch (Exception e)        {            trans.Rollback();            SAEC_Log4net.Log.Error(e.ToString());            id = 0;            return false;        }    }}

 

SQLite資料庫中擷取新插入資料的自增長ID

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.