تقييم الموضوع :
  • 0 أصوات - بمعدل 0
  • 1
  • 2
  • 3
  • 4
  • 5
[سؤال] تنظيم ارفاق المستندات في قاعدة البيانات Sql واحضار الملفات حسب قيمة البحث
#1
اخواني الاعزاء
 اسعد الله اوقاتكم بكل خير واتمنى ان تكونوا جميعا في اتم صحه وعافيه
لدى قاعده البيانات التاليه والتي تتكون من الحقول كما في الصورة التالية:
   
والمراد منها عمل حفظ لمستندات ومرفقات ووثائق الموظفين ولكن واجه مشكله في حفظ المستند واعاده قراءته من قاعده البيانات حيث يتم حفظ المرفق بجانب ملف التشغيل والمطلوب ان يتم الحفظ في ملف خاص ولا يمكن قراءه المستندات الا عن طريق اعاده فتحه من خلال البرنامج.


المشكله الاخرى تكمن في حال تم عمل فلتر او بحث برقم الموظف "EmployeID" في Data grid view
لا يتم احضار الملفات والمرفقات التي تخص الرقم الوظيفي للموظف بل يتم عرض أول المرفقات

كود :
USE [Test_System]
GO

/****** Object:  Table [dbo].[Tbl_doc]    Script Date: 06/Sep/2020 12:27:45 AM ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[Tbl_doc](
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [Employe] [int] NULL,
    [Filestatus] [nvarchar](50) NULL,
    [Extension] [nvarchar](50) NULL,
    [FileName] [nvarchar](50) NULL,
    [Attached] [varbinary](max) NULL,
    [Remarks] [nvarchar](255) NULL,
CONSTRAINT [PK_Tbl_doc] PRIMARY KEY CLUSTERED
(
    [ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO
لا إله إلا الله وحده لا شريك له، لهُ الملك وله الحمد وهو على كل شئ قدير،،،،
سبحان الله وبحمده سبحان الله العظيم Heart
الرد }}}
تم الشكر بواسطة:
#2
(06-09-20, 01:28 AM)محمد العامر كتب : اخواني الاعزاء
 اسعد الله اوقاتكم بكل خير واتمنى ان تكونوا جميعا في اتم صحه وعافيه
لدى قاعده البيانات التاليه والتي تتكون من الحقول كما في الصورة التالية:


والمراد منها عمل حفظ لمستندات ومرفقات ووثائق الموظفين ولكن واجه مشكله في حفظ المستند واعاده قراءته من قاعده البيانات حيث يتم حفظ المرفق بجانب ملف التشغيل والمطلوب ان يتم الحفظ في ملف خاص ولا يمكن قراءه المستندات الا عن طريق اعاده فتحه من خلال البرنامج.


المشكله الاخرى تكمن في حال تم عمل فلتر او بحث برقم الموظف "EmployeID" في Data grid view
لا يتم احضار الملفات والمرفقات التي تخص الرقم الوظيفي للموظف بل يتم عرض أول المرفقات

كود :
USE [Test_System]
GO

/****** Object:  Table [dbo].[Tbl_doc]    Script Date: 06/Sep/2020 12:27:45 AM ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[Tbl_doc](
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [Employe] [int] NULL,
    [Filestatus] [nvarchar](50) NULL,
    [Extension] [nvarchar](50) NULL,
    [FileName] [nvarchar](50) NULL,
    [Attached] [varbinary](max) NULL,
    [Remarks] [nvarchar](255) NULL,
CONSTRAINT [PK_Tbl_doc] PRIMARY KEY CLUSTERED
(
    [ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO

الطريقة الصحيحة هي أن يكون هناك جدول للمرفقات يكون فيها الحقول الأساسية التالية:
كود :
ID        INT IDENTITY(1,1) PRIMARY KEY
Emp_ID    INT
Filename  NVarChar(255)
Attached  VARBINARY(MAX)
ويمكن إضافة التالي
كود :
Remarks   NVarChar(255)

وجدول الموظفين يكون عادي بدون مرفقات
ثم تربط بين جدول المرفقات العمود Emp_ID مع جدول الموظفين العمود ID


وعند إضافة مرفقات تضيف المرفق في جدول المرفقات بحيث يكون رقم Emp_ID بنفس رقم ID الخاص بالموظف المراد تسجيل المرفق له

وسيكون هناك رد آخر لكيفية الاستعلام لجميع مرفقات موظف
الرد }}}
تم الشكر بواسطة: محمد العامر , حريف برمجة , WaeLx
#3
نعم اخي هذا يعتبر جدول خاص بالملفات فقط منفصل عن بيانات الموظفين
لا إله إلا الله وحده لا شريك له، لهُ الملك وله الحمد وهو على كل شئ قدير،،،،
سبحان الله وبحمده سبحان الله العظيم Heart
الرد }}}
تم الشكر بواسطة: حريف برمجة
#4
كيف طريقتك في الاستعلام مع وضع كود الاستعلام
لان هناك عدة طرق للتعامل مع البيانات

ولو تضع مشروع يكون أفضل لسرعة تلبية طلبك
الرد }}}
تم الشكر بواسطة: حريف برمجة , حريف برمجة , WaeLx , WaeLx
#5
كود :
SELECT TB_AllEemplooyeJed.EemployeID, TB_AllEemplooyeJed.EemployeName, TB_File.ID, TB_File.FileName, TB_File.FileExt, TB_File.Attachment, TB_File.Statuss, TB_File.EemployeID AS Expr1
FROM     TB_AllEemplooyeJed RIGHT OUTER JOIN
                 TB_File ON TB_AllEemplooyeJed.EemployeID = TB_File.EemployeID
WHERE  (TB_AllEemplooyeJed.EemployeID = EemployeID )", ConSql)

هذا كود الاستعلام
لا إله إلا الله وحده لا شريك له، لهُ الملك وله الحمد وهو على كل شئ قدير،،،،
سبحان الله وبحمده سبحان الله العظيم Heart
الرد }}}
تم الشكر بواسطة: حريف برمجة , WaeLx , WaeLx
#6
(06-09-20, 03:29 PM)محمد العامر كتب :
كود :
SELECT TB_AllEemplooyeJed.EemployeID, TB_AllEemplooyeJed.EemployeName, TB_File.ID, TB_File.FileName, TB_File.FileExt, TB_File.Attachment, TB_File.Statuss, TB_File.EemployeID AS Expr1
FROM     TB_AllEemplooyeJed RIGHT OUTER JOIN
                 TB_File ON TB_AllEemplooyeJed.EemployeID = TB_File.EemployeID
WHERE  (TB_AllEemplooyeJed.EemployeID = EemployeID )", ConSql)

هذا كود الاستعلام

من مشاهدة الاستعلام يبدو سليما باستثناء عدم وضعك علامة @ قبل اسم الباراميتر EemployeID
كود :
SELECT TB_AllEemplooyeJed.EemployeID, TB_AllEemplooyeJed.EemployeName, TB_File.ID, TB_File.FileName, TB_File.FileExt, TB_File.Attachment, TB_File.Statuss, TB_File.EemployeID AS Expr1
FROM     TB_AllEemplooyeJed RIGHT OUTER JOIN
                 TB_File ON TB_AllEemplooyeJed.EemployeID = TB_File.EemployeID
WHERE  (TB_AllEemplooyeJed.EemployeID = @EemployeID )", ConSql)

يبقى كيفية عرض المرفقات

إذا أردت حل سريع ضع مشروع
أو راسلني على الخاص إن كان لا يمكنك وضع المشروع للجميع

مع توضيح ماذا تقصد بـ (الحفظ في ملف خاص)
الرد }}}
تم الشكر بواسطة: حريف برمجة , حريف برمجة , WaeLx
#7
جزاك الله كل خير

سكربت قاعدة البيانات التي تحتوي على بيانات الموظفين

كود :
CREATE TABLE [dbo].[TB_AllEemplooyeJed](
    [Sril] [int] IDENTITY(1,1) NOT NULL,
    [EemployeID] [int] NOT NULL,
    [EemployeName] [nvarchar](255) NULL,
CONSTRAINT [PK_TB_AllEemplooyeJed] PRIMARY KEY CLUSTERED
(
    [Sril] ASC,
    [EemployeID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

وهذا سكربت جدول الملفات 

كود :
CREATE TABLE [dbo].[TB_File](
    [id] [int] IDENTITY(1,1) NOT NULL,
    [FileName] [nvarchar](50) NOT NULL,
    [FileExt] [nvarchar](50) NOT NULL,
    [Attachment] [varbinary](max) NOT NULL,
CONSTRAINT [PK_TB_File] PRIMARY KEY CLUSTERED
(
    [id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]
لا إله إلا الله وحده لا شريك له، لهُ الملك وله الحمد وهو على كل شئ قدير،،،،
سبحان الله وبحمده سبحان الله العظيم Heart
الرد }}}
تم الشكر بواسطة: حريف برمجة , WaeLx
#8
(06-09-20, 04:18 PM)محمد العامر كتب : جزاك الله كل خير

سكربت قاعدة البيانات التي تحتوي على بيانات الموظفين

كود :
CREATE TABLE [dbo].[TB_AllEemplooyeJed](
    [Sril] [int] IDENTITY(1,1) NOT NULL,
    [EemployeID] [int] NOT NULL,
    [EemployeName] [nvarchar](255) NULL,
CONSTRAINT [PK_TB_AllEemplooyeJed] PRIMARY KEY CLUSTERED
(
    [Sril] ASC,
    [EemployeID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

وهذا سكربت جدول الملفات 

كود :
CREATE TABLE [dbo].[TB_File](
    [id] [int] IDENTITY(1,1) NOT NULL,
    [FileName] [nvarchar](50) NOT NULL,
    [FileExt] [nvarchar](50) NOT NULL,
    [Attachment] [varbinary](max) NOT NULL,
CONSTRAINT [PK_TB_File] PRIMARY KEY CLUSTERED
(
    [id] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

الجدول TB_File لا يوجد فيه عمود رقم الموظف EemployeID
في حين أن الاستعلام الذي وضعته أشار لذلك TB_File.EemployeID
هناك عدم تطابق لما تضعه


أيضا لم ترد على مشاركتي السابقة
الرد }}}
تم الشكر بواسطة: حريف برمجة , حريف برمجة , WaeLx
#9
(06-09-20, 03:46 PM)L35 كتب :
(06-09-20, 03:29 PM)محمد العامر كتب :
كود :
SELECT TB_AllEemplooyeJed.EemployeID, TB_AllEemplooyeJed.EemployeName, TB_File.ID, TB_File.FileName, TB_File.FileExt, TB_File.Attachment, TB_File.Statuss, TB_File.EemployeID AS Expr1
FROM     TB_AllEemplooyeJed RIGHT OUTER JOIN
                 TB_File ON TB_AllEemplooyeJed.EemployeID = TB_File.EemployeID
WHERE  (TB_AllEemplooyeJed.EemployeID = EemployeID )", ConSql)

هذا كود الاستعلام

من مشاهدة الاستعلام يبدو سليما باستثناء عدم وضعك علامة @ قبل اسم الباراميتر EemployeID
كود :
SELECT TB_AllEemplooyeJed.EemployeID, TB_AllEemplooyeJed.EemployeName, TB_File.ID, TB_File.FileName, TB_File.FileExt, TB_File.Attachment, TB_File.Statuss, TB_File.EemployeID AS Expr1
FROM     TB_AllEemplooyeJed RIGHT OUTER JOIN
                 TB_File ON TB_AllEemplooyeJed.EemployeID = TB_File.EemployeID
WHERE  (TB_AllEemplooyeJed.EemployeID = @EemployeID )", ConSql)

يبقى كيفية عرض المرفقات

إذا أردت حل سريع ضع مشروع
أو راسلني على الخاص إن كان لا يمكنك وضع المشروع للجميع

مع توضيح ماذا تقصد بـ (الحفظ في ملف خاص)

اشكرك على رحابة صدرك كتب الله اجرك يا أخي
القصد بحفظ الملفات التي يتم أرفاقه في قاعدة بملف خاص أي أنه في حال تم حفظ الملف كنوع من التنظيم يتم حفظه في ملف داخل \Debug عكس ما يتم في الملف المرفق
http://vb4arb.com/vb/showthread.php?tid=28906
هذا ما أقدصه

كود :
CREATE TABLE [dbo].[TB_File](
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [EemployeID] [int] NOT NULL,
    [FileName] [nvarchar](50) NULL,
    [FileExt] [nvarchar](50) NULL,
    [Attachment] [varbinary](max) NULL,
CONSTRAINT [PK_TB_File] PRIMARY KEY CLUSTERED
(
    [ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO
لا إله إلا الله وحده لا شريك له، لهُ الملك وله الحمد وهو على كل شئ قدير،،،،
سبحان الله وبحمده سبحان الله العظيم Heart
الرد }}}
تم الشكر بواسطة: حريف برمجة , حريف برمجة , WaeLx
#10
(06-09-20, 04:43 PM)محمد العامر كتب :
(06-09-20, 03:46 PM)L35 كتب :
(06-09-20, 03:29 PM)محمد العامر كتب :
كود :
SELECT TB_AllEemplooyeJed.EemployeID, TB_AllEemplooyeJed.EemployeName, TB_File.ID, TB_File.FileName, TB_File.FileExt, TB_File.Attachment, TB_File.Statuss, TB_File.EemployeID AS Expr1
FROM     TB_AllEemplooyeJed RIGHT OUTER JOIN
                 TB_File ON TB_AllEemplooyeJed.EemployeID = TB_File.EemployeID
WHERE  (TB_AllEemplooyeJed.EemployeID = EemployeID )", ConSql)

هذا كود الاستعلام

من مشاهدة الاستعلام يبدو سليما باستثناء عدم وضعك علامة @ قبل اسم الباراميتر EemployeID
كود :
SELECT TB_AllEemplooyeJed.EemployeID, TB_AllEemplooyeJed.EemployeName, TB_File.ID, TB_File.FileName, TB_File.FileExt, TB_File.Attachment, TB_File.Statuss, TB_File.EemployeID AS Expr1
FROM     TB_AllEemplooyeJed RIGHT OUTER JOIN
                 TB_File ON TB_AllEemplooyeJed.EemployeID = TB_File.EemployeID
WHERE  (TB_AllEemplooyeJed.EemployeID = @EemployeID )", ConSql)

يبقى كيفية عرض المرفقات

إذا أردت حل سريع ضع مشروع
أو راسلني على الخاص إن كان لا يمكنك وضع المشروع للجميع

مع توضيح ماذا تقصد بـ (الحفظ في ملف خاص)

اشكرك على رحابة صدرك كتب الله اجرك يا أخي
القصد بحفظ الملفات التي يتم أرفاقه في قاعدة بملف خاص أي أنه في حال تم حفظ الملف كنوع من التنظيم يتم حفظه في ملف داخل \Debug عكس ما يتم في الملف المرفق
http://vb4arb.com/vb/showthread.php?tid=28906
هذا ما أقدصه

كود :
CREATE TABLE [dbo].[TB_File](
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [EemployeID] [int] NOT NULL,
    [FileName] [nvarchar](50) NULL,
    [FileExt] [nvarchar](50) NULL,
    [Attachment] [varbinary](max) NULL,
CONSTRAINT [PK_TB_File] PRIMARY KEY CLUSTERED
(
    [ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
GO


هذا المشروع كان مساعدة لي من أحد الأصدقاء
حذفت منه الإضافات الخاصة بي
لعلك تجد فيه الفائدة

.rar   WindowsApplication1.rar (الحجم : 153.64 ك ب / التحميلات : 31)
الرد }}}


المواضيع المحتمل أن تكون متشابهة .
الموضوع : الكاتب الردود : المشاهدات : آخر رد
  أريد البحث بإستخدام أي جزء من الكلمة و ليس أول جزء منها . CoderMM 2 41 منذ 4 ساعة مضت
آخر رد: قناص المدينة
  هل من الممكن العمل على قاعدة بيانات اكسل على الفيجوال بيسك خالد كامل1 4 141 24-03-24, 02:00 AM
آخر رد: خالد كامل1
  [VB.NET] حل مشكلة الاتصال بقواعد البيانات access loay775 2 168 25-02-24, 06:29 AM
آخر رد: loay775
  [VB.NET] البحث باستخدام CheckedListBox لتكون نتيجة التحديد شرط لجملة الاستعلام ahmedramzyaish 0 123 19-02-24, 03:44 AM
آخر رد: ahmedramzyaish
  انشاء قاعدة بيانات من ملف سكربت strongriseman 5 507 17-02-24, 02:57 PM
آخر رد: strongriseman
  سؤال عن عملية حذف سجل من قاعدة البيانات assuhimi 3 260 11-02-24, 08:43 PM
آخر رد: assuhimi
  فلترة datagridview بدون قاعدة بيانات صالح عبدالله 3 314 02-02-24, 04:07 PM
آخر رد: صالح عبدالله
  البحث بالهوية annagui 2 323 25-01-24, 01:00 PM
آخر رد: annagui
  [VB.NET] منع تكرار البيانات في عند الادخال مبرمج صغير 1 2 266 24-01-24, 05:18 PM
آخر رد: مبرمج صغير 1
Photo [كود] مطلوب كود يستخدم الأوامر فقط لتحديث قاعدة بيانات بـ vb.net AhmedEissa 4 649 18-01-24, 11:40 PM
آخر رد: العتيق

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


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