ถามเรื่อง insert ใน Sql CE หน่อยค่า

Last post 6 Nov 2009 17:08 by dekchaiake. 9 replies.
Page 1 of 2 (10 items) 1 2 Next >
Sort Posts: Previous Next
  • 29 May 2008 10:50

    ถามเรื่อง insert ใน Sql CE หน่อยค่า

    คือว่าสงสัยอ่าค่ะว่า ถ้าเกิดมีอยู่ 2 form อย่างงี้อ่าค่ะ Form แรกเอาไว้แสดงข้อมูลใสฐานข้อมูลค่ะ ส่วนอีกพร้อมต้องกด new เพื่อที่จะทำการ insert แต่ว่าพอ insert แล้วจะมีเรียกดูอีก form นึงไม่ได้อ่าค่ะ ทั้งๆที่ update ได้ด้วยนะค่ะ เป็นเพราะอะไรอ่าค่ะ หรือว่าถ้าจะอัพเดทให้เห็นเลยทันทีต้องอยู่ใน Form เดียวกันหรอค่ะ ขอบพระคุณค่ะ
  • 30 May 2008 0:28 In reply to

    Re: ถามเรื่อง insert ใน Sql CE หน่อยค่า

    อาจจะเป็นเรื่องของ concurrency อ่ะคับ ปกติไม่เคยทดลอง หรือเจอเองเหมือนกัน ลองสั่งให้ form1 close connection ก่อนดิครับ อย่างน้อยข้อมูลมันก้อน่าจะเขียนลงไปในไฟล์ ให้เรา select ออกมาได้ใน form2 ตัว sqlce อาจจะแยกไม่ให้ connection ต่างกัน ไม่สามารถมองเห็นข้อมูลข้ามกันได้ (ประมาณว่า แยกกัน คนละ transaction) ถ้าเป็นไปได้ ลองใช้ connection ตัวเดียวกันเลยดิคับ ว่ามันหายมั๊ย

     

  • 30 May 2008 8:29 In reply to

    Re: ถามเรื่อง insert ใน Sql CE หน่อยค่า

    หวัดดีค่า คือตอนนี้อ่าค่ะ ย้ายมาอยู่ Form เดียวกันแล้ว เปิด ปิด connection ใหม่แล้วด้วยอ่าค่ะ แต่ว่าพอ SELECT จะูดูข้อมูลที่เพิ่งใส่เข้าไปอ่ะค่ะ มันไม่มี แต่ว่าพอเปิดโปรแกรม แล้วรันโปรแกรมใหม่และ SELECT ดูใหม่ ปรากฏว่ามันขึ้นมาแล้วอ่าค่ะ ก็เลยงง ไปไม่เป็นเลยอ่าค่ะ -_-!
  • 4 Jun 2008 17:43 In reply to

    Re: ถามเรื่อง insert ใน Sql CE หน่อยค่า

    ผมว่า ลองดัก Try{}Catch{} ที่ Connection ดูนะครับ เพราะ Database sqlCE สามารถที่จะ Open Conneciton ได้ทีละ 1 Connection นะครับ ถ้า สร้าง SqlCeConnection sqlConn = new SqlCeConnection(); try{ sqlConn.Open() ******sql Command******* } catch{ } finally{ sqlConn.Close() }
  • 12 Jun 2008 10:44 In reply to

    Re: ถามเรื่อง insert ใน Sql CE หน่อยค่า

    ลองเอาโค๊ดมาดูหน่อยได้ป่ะคับ ว่าเปิดปิดยังไง

    ถ้าให้ดูไม่ได้ (หวง) ก้อลองใช้ using ด้วยอ่ะคับ แบบนี้ จะได้ชัวร์ว่ามันปิดแน่ๆ

    using( SqlCeConnection conn = .... )
    {

         conn.Close();

    }

  • 12 Jun 2008 21:54 In reply to

    Big Smile [:D] Re: ถามเรื่อง insert ใน Sql CE หน่อยค่า

    แก้ได้เรียบร้อยแล้วค่า string path = Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().GetName().CodeBase); SqlCeConnection conn = new SqlCeConnection("Data Source = " + path + "//MyDatabase#1.sdf"); ตอนแรกใส่ conn.Open() ไ้ว้ตรงนี้อ่าค่ะ พอเอาออกปุ๊บ มันก็ insert ได้ปกติเลยอ่าค่ะ งงเหมือนกันอ่าค่ะ มีใครทราบรึเปล่าค่ะ ว่าทำไม adapt = new SqlCeDataAdapter("SELECT * FROM [UserDetail]", conn); data = new DataSet(); SqlCeCommandBuilder cmdBuilder = new SqlCeCommandBuilder(adapt); adapt.Fill(data, "UserTable"); ขอบคุณนะค่ะ
  • 15 Jun 2008 1:57 In reply to

    Re: ถามเรื่อง insert ใน Sql CE หน่อยค่า

    string path = Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().GetName().CodeBase);
    SqlCeConnection conn = new SqlCeConnection("Data Source = " + path + "//MyDatabase#1.sdf");
    adapt = new SqlCeDataAdapter("SELECT * FROM [UserDetail]", conn);
    data = new DataSet();
    SqlCeCommandBuilder cmdBuilder = new SqlCeCommandBuilder(adapt);
    adapt.Fill(data, "UserTable"); 

    อันนี้คือโค๊ดที่ผมเห็นนะคับ ดูแล้วก้อยังงงๆ นิดนึงอะ เหอๆ

    แต่เรื่องของเรื่องคือว่า ถ้าเราทำแบบนี้

    SqlCeConnection conn = new SqlCeConnection("Data Source = " + path + "//MyDatabase#1.sdf");
    conn.Open()

    SqlCeConnection conn2 = new SqlCeConnection("Data Source = " + path + "//MyDatabase#1.sdf");
    conn2.Open()

    conn กะ conn2 จะเหมือนว่า ทำงานอยู่คนละ Database ดังนั้น ถ้าผมใช้ conn ในการ Insert แล้วใช้ conn2 ในการ Select มันก้อจะมองข้อมูลจาก conn ไม่เห็นคับ จนกว่า conn จะสั่ง Close ไปอ่ะคับ

     

  • 17 Jun 2008 9:40 In reply to

    Re: ถามเรื่อง insert ใน Sql CE หน่อยค่า

    SqlCeConnection conn = new SqlCeConnection("Data Source = " + path + "//MyDatabase#1.sdf"); conn.Open() SqlCeConnection conn2 = new SqlCeConnection("Data Source = " + path + "//MyDatabase#1.sdf"); conn2.Open() ถ้าเราใช้ conn.Open แล้ว Insert ไป เสร็จแล้วไม่ Close Connection เราจะไม่สามารถใช้ conn2.Open ได้นะครับ เพราะDatabase 1ตัว สามารถ Open Connection ได้ทีละ 1 connection มันน่าจะประมาณนี้หรือเปล่า SqlCeConnection conn = new SqlCeConnection("Data Source = " + path + "//MyDatabase#1.sdf"); conn.Open() conn.Close() SqlCeConnection conn2 = new SqlCeConnection("Data Source = " + path + "//MyDatabase#1.sdf"); conn2.Open() conn2.Close()
Page 1 of 2 (10 items) 1 2 Next >