تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
[VB.NET] استفسار :- رقم الاي دي لاخر ادخال في قاعدة البيانات
#1
السلام عليكم ورحمة الله

محتاد طريقه اطلع فيها رقم الاي دي  بعد عمليه ال INSERT

هذا الكود

كود :
       conx = New SQLiteConnection(String.Format("Data Source= C:\LOG\{0}\DB{1}.s3db", strcallbk,test))
       cmdx = New SQLiteCommand("INSERT INTO DBQTC (station, UTC) Values (@station,@UTC") With {
           .Connection = conx
       }

 conx.Open()
           cmdx.Parameters.AddWithValue("@station", strcallbk)
           cmdx.Parameters.AddWithValue("@UTC", timk)

       cmdx.ExecuteNonQuery()
         conx.Close()


محتاج بعد الانزال يطلع لي رقم الاي دي ID  لهذا الادخال

وشكرا بارك الله فيكم
الرد
تم الشكر بواسطة:
#2
السلام عليكم اخي الكريم
ان كنت تريد رقم id للادخال الذي ادهلته للتو بعد كود الحفظ
فقط استخدم  كود max id مع انقاص رقم واحد
قم بانشاء  label وضع له هذا الكود
ولتكن هكذا


كود :
Label1.Text = (MaxID("اسم الجدول").Rows(0)(0)) - 1




اما ان كنت تقصد max id فلا تنقص منه سيأتي بأخر قيمة +1
كود :
Txt_id.Text = (MaxID_("اسم الجدول").Rows(0)(0))
الرد
تم الشكر بواسطة: dubai.eig , elgokr
#3
بعد تعديل الكود أصبح كالتالي :

كود :
conx = New SQLiteConnection(String.Format("Data Source= C:\LOG\{0}\DB{1}.s3db", strcallbk,test))
cmdx = New SQLiteCommand("INSERT INTO DBQTC (station, UTC) Values (@station,@UTC") With {
.Connection = conx}

conx.Open()
cmdx.Parameters.AddWithValue("@station", strcallbk)
cmdx.Parameters.AddWithValue("@UTC", timk)
cmdx.ExecuteNonQuery()

'------------------------------------
cmdx.CommandText = "SELECT SCOPE_IDENTITY()"
Dim NewID As Integer
NewID = cmdx.ExecuteScalar()
'------------------------------------

conx.Close()

الآن المتغير NewID سيحمل قيمة رقم الـ ID الجديد

الإستعلام : SELECT SCOPE_IDENTITY
يقوم بإرجاع آخر رقم ID تم إنشائة 

كما يمكنك إستخدام : SELECT @@IDENTITY




هذا هو الفرق بين SCOPE_IDENTITY وبين IDENTITY@@

SELECT @@IDENTITY
It returns the last IDENTITY value produced on a connection, regardless of the table that produced the value, and regardless of the scope of the statement that produced the value.
@@IDENTITY will return the last identity value entered into a table in your current session. While @@IDENTITY is limited to the current session, it is not limited to the current scope. If you have a trigger on a table that causes an identity to be created in another table, you will get the identity that was created last, even if it was the trigger that created it.


SELECT SCOPE_IDENTITY()
It returns the last IDENTITY value produced on a connection and by a statement in the same scope, regardless of the table that produced the value.

SCOPE_IDENTITY(), like @@IDENTITY, will return the last identity value created in the current session, but it will also limit it to your current scope as well. In other words, it will return the last identity value that you explicitly created, rather than any identity that was created by a trigger or a user defined function.



الرد
تم الشكر بواسطة: dubai.eig , dubai.eig , elgokr
#4
(15-09-18, 12:19 AM)ابراهيم ايبو كتب : السلام عليكم اخي الكريم
ان كنت تريد رقم id للادخال الذي ادهلته للتو بعد كود الحفظ
فقط استخدم  كود max id مع انقاص رقم واحد
قم بانشاء  label وضع له هذا الكود
ولتكن هكذا


كود :
Label1.Text = (MaxID("اسم الجدول").Rows(0)(0)) - 1




اما ان كنت تقصد max id فلا تنقص منه سيأتي بأخر قيمة +1
كود :
Txt_id.Text = (MaxID_("اسم الجدول").Rows(0)(0))

تسلم عزيزي على الرد

بس ما اللي اقصده يختلف عن اللي كتبته عزيزي 
بارك الله فيك

(15-09-18, 12:38 AM)عبدالله الدوسري كتب : بعد تعديل الكود أصبح كالتالي :

كود :
conx = New SQLiteConnection(String.Format("Data Source= C:\LOG\{0}\DB{1}.s3db", strcallbk,test))
cmdx = New SQLiteCommand("INSERT INTO DBQTC (station, UTC) Values (@station,@UTC") With {
.Connection = conx}

conx.Open()
cmdx.Parameters.AddWithValue("@station", strcallbk)
cmdx.Parameters.AddWithValue("@UTC", timk)
cmdx.ExecuteNonQuery()

'------------------------------------
cmdx.CommandText = "SELECT SCOPE_IDENTITY()"
Dim NewID As Integer
NewID = cmdx.ExecuteScalar()
'------------------------------------

conx.Close()

الآن المتغير NewID سيحمل قيمة رقم الـ ID الجديد

الإستعلام : SELECT SCOPE_IDENTITY
يقوم بإرجاع آخر رقم ID تم إنشائة 

كما يمكنك إستخدام : SELECT @@IDENTITY




هذا هو الفرق بين SCOPE_IDENTITY وبين IDENTITY@@

SELECT @@IDENTITY
It returns the last IDENTITY value produced on a connection, regardless of the table that produced the value, and regardless of the scope of the statement that produced the value.
@@IDENTITY will return the last identity value entered into a table in your current session. While @@IDENTITY is limited to the current session, it is not limited to the current scope. If you have a trigger on a table that causes an identity to be created in another table, you will get the identity that was created last, even if it was the trigger that created it.


SELECT SCOPE_IDENTITY()
It returns the last IDENTITY value produced on a connection and by a statement in the same scope, regardless of the table that produced the value.

SCOPE_IDENTITY(), like @@IDENTITY, will return the last identity value created in the current session, but it will also limit it to your current scope as well. In other words, it will return the last identity value that you explicitly created, rather than any identity that was created by a trigger or a user defined function.




تسلم على الرد بارك الله فيك 
طلع لي مسج غلط

   
الرد
تم الشكر بواسطة: ابراهيم ايبو
#5
SELECT ID FROM TABLE_NAME ORDER BY ID DESC LIMIT 1
الرد
تم الشكر بواسطة: dubai.eig , dubai.eig , elgokr
#6
(15-09-18, 12:46 AM)dubai.eig كتب : تسلم على الرد بارك الله فيك 
طلع لي مسج غلط



أعتذر لأنني أعتقدت أنها SQL

على العموم إستخدم هذة بدلاً عنها : 

SELECT last_insert_rowid()
الرد
تم الشكر بواسطة: dubai.eig , dubai.eig , ابراهيم ايبو , elgokr
#7
(15-09-18, 01:24 AM)عبدالله الدوسري كتب :
(15-09-18, 12:46 AM)dubai.eig كتب : تسلم على الرد بارك الله فيك 
طلع لي مسج غلط



أعتذر لأنني أعتقدت أنها SQL

على العموم إستخدم هذة بدلاً عنها : 

SELECT last_insert_rowid()

نعم ضبط معاي شكرا لك بارك الله فيك

الحمدالله تسلم على وقتك

(15-09-18, 12:58 AM)أبوبكر سويدان كتب : SELECT ID FROM TABLE_NAME ORDER BY ID DESC LIMIT 1

شكرا استاذي ابوبكر الحمدالله حصلت الجل في رد استاذي عبدالله شكرا لك
الرد
تم الشكر بواسطة: عبدالله الدوسري , elgokr
#8
وعليكم السلام ورحمة الله وبركاته

مشاء الله الاخوة لم تقصر بالحل
وليس هذا فقط بال تواجد كلاً من 

[*] عبدالله الدوسري
[*] أبوبكر سويدان

عودة حميدة يارب


حتى الاخ ابراهيم ايبو اتى بالرد المناسب ايضاً

لكن يبدو انه لم تصل فكرته لك فكل الشكر والتقدير للمساعدة فى الرد

واتمنى ان تكون دائماً وان لا يتوقف بما يعلمه للغير حتى تعم العلم والائدة للجميع


فكل الشكر والتقدير للجميع


تحياتى لكم

وتمنياتى لكم التوفيق الدائم
{ وَقُل رَّبِّ زِدْنِي عِلْمًا }
[ كن على يقين من اعمالنا نخطئ ومن اخطائنا نتعلم ولذلك لا شي مستحيل ]

ساهم دائماً فى تقديم   لكل من يقوم بالمساهمة
فى حل اى مشكلة او استفسار لديك مع اضافة رد بشكره ودعوة له
فالجميع هنا يعمل على مساعدة الاخرين لوجه الله وان تحتسب له اجر عند الله
الرد
تم الشكر بواسطة: dubai.eig , dubai.eig


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  [سؤال] استفسار عن مشكلة في كود لايجاد العملاء الغير موجودين بجدول الدفع ahmedmansour 10 218 أمس, 09:05 PM
آخر رد: ahmedmansour
Exclamation [سؤال] اخطاء بقاعدة البيانات DK-x 5 92 أمس, 08:18 PM
آخر رد: elgokr
  [VB.NET] استفسار :- التاكد من الوقت بين وقتين dubai.eig 3 55 أمس, 07:18 PM
آخر رد: elgokr
  عندي مشكلة في قاعدة البيانات SonBasel 11 243 أمس, 06:34 PM
آخر رد: SonBasel
  [VB.NET] استفسار :- بخصوص تغيير اسم ال Button بعد الضغط dubai.eig 10 163 17-09-18, 10:53 AM
آخر رد: dubai.eig
  استفسار عن حماية او كسر البرامج مجموعه اسئله قد يكون الحل ارجو المساعده thementalist 1 72 15-09-18, 08:21 PM
آخر رد: عبدالله الدوسري
  [سؤال] استفسار عن فيجوال ستديو اصدار 2015 essawq 15 277 15-09-18, 05:36 PM
آخر رد: essawq
  ممكن مساعده اريد وضع مواعيد للحجوزات وعند ادخال قيمة وقت معين يعطي رساله بان الوقت ده thementalist 6 109 14-09-18, 08:47 PM
آخر رد: حريف برمجة
Exclamation [سؤال] كيفية التعامل مع قاعدة البيانات DK-x 3 64 13-09-18, 05:03 PM
آخر رد: elgokr
  مُشكلة في حفظ البيانات داخل الداتاجريدفيو في بعض الأحيان Hazem1 7 172 10-09-18, 09:34 PM
آخر رد: Hazem1

التنقل السريع :


يقوم بقرائة الموضوع: بالاضافة الى ( 1 ) ضيف كريم