c# update Oracle帶參數 寫法

來源:互聯網
上載者:User

標籤:style   blog   http   color   os   io   資料   ar   問題   

剛剛從MySql/MSSQL資料庫轉到Oracle,用C#調用時一直更新不成功 ,後來發現是傳參數格式不正確的問題。

Oracle裡的command 要在參數名前用冒號:標註。SqlServer和MySQL都是用@。見http://www.codeproject.com/Questions/618582/ORA-00936-missing-expression
public static bool UpdateNew(Entity.PW_User NewUser)        {            try            {                Entity.PW_User tt = NewUser;                              StringBuilder sb = new StringBuilder();                sb.Append(" update pw_User set ");                sb.Append(" UserName=:UserName, ");                sb.Append(" Password=:Password, ");                sb.Append(" UserGroupCode=:UserGroupCode, ");                sb.Append(" CreateTime=:CreateTime, ");                sb.Append(" LastLoginTime=:LastLoginTime  ");                sb.Append(" where UserID=:UserID ");                //Oracle裡的command 要在參數名前用冒號:標註。SqlServer和MySQL都是用@。                //見-----http://www.codeproject.com/Questions/618582/ORA-00936-missing-expression                OracleCommand cmd = new OracleCommand();                cmd.CommandText = sb.ToString();                cmd.CommandType = CommandType.Text;                //下面添加參數的順序一定要跟上面的語句裡各參數出現的順序一致。否則更新不成功。                //如下面的UserID參數不能先於前面5個參數的任何一個出現。                cmd.Parameters.Add(new OracleParameter("UserName", OracleDbType.NVarchar2, 45) { Value = tt.UserName });                cmd.Parameters.Add(new OracleParameter("Password", OracleDbType.Varchar2, 45) { Value = tt.Password });                cmd.Parameters.Add(new OracleParameter("UserGroupCode", OracleDbType.Varchar2, 45) { Value = tt.UserGroupCode });                cmd.Parameters.Add(new OracleParameter("CreateTime", OracleDbType.Varchar2, 45) { Value = tt.CreateTime });                cmd.Parameters.Add(new OracleParameter("LastLoginTime", OracleDbType.Varchar2, 45) { Value = tt.LastLoginTime });                cmd.Parameters.Add(new OracleParameter("UserID", OracleDbType.Varchar2, 50) { Value = tt.UserID });                int val = DBHelper_Oracle. ExecuteNonQuery(cmd);                if (val > 0)                {                    return true;                }                else                {                    return false;                }            }            catch            {                return false;            }        }

希望對大家有用 。

c# update Oracle帶參數 寫法

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.