PDA

نسخه کامل مشاهده نسخه کامل : تمامي سوالات و مسايل راجع به SQL Server



مهمان
12-05-2005, 17:01
سلام دوستان
اين هم تاپيک sql server که ديتابيسي بسيار مناسب براي برنامه نويسهاي ايراني مي باشد. :)

nazila
15-05-2005, 12:38
من به يك مشكل برخورد كردم... :? درواقع من در جايي كار ميكنم كه يك Sql Server 2000 نصب است و افراد گوناگوني با آن كار ميكنند چند وقتي است كه Sql Server Agent از كار افتاده و job ها اجرا نميشوند.بدين معنا كه Sql Server Agent Start نمي شود. با اين عنوان تمام سايتهاي ممكن كه راه حلي اراپه داده بودند را رفتم ولي به نتيجه نرسيدم. درواقع بدون دادن Error اين سرويس Start نميشه.
من از log اون يك كپي هم برداشتم كه بد نيست اين پايين بيارمش...
2005-04-25 14:09:16 - ! [165] ODBC Error: 0, Cannot generate SSPI context [SQLSTATE HY000]
2005-04-25 14:09:16 - ! [000] Unable to connect to server '(local)'; SQLServerAgent cannot start
2005-04-25 14:09:17 - ? [098] SQLServerAgent terminated (normally)
همچنين services رو هم دستي اجرا كردم ولي فايده اي نداشت. چي كار كنم؟

مهمان
15-05-2005, 22:24
سلام
بهتره properties مربوط به Sql Server Agent را چک نماييد.
شايد هم آي پي يا نوع login به هم خورده باشند.
براي اطلاعات بيشتر راجع به error مورد نظر شما به لينک زير مراجعه نماييد:
[ برای مشاهده لینک ، لطفا با نام کاربری خود وارد شوید یا ثبت نام کنید ]
يا علي :)

ooje_asman
16-05-2005, 06:29
با سلام خدمت رامبد جان می شه این برنامه رو از اول اول توضیح بدین لطفا

Nesta
16-05-2005, 16:33
سلام
آقای اجه آسمان اين برنامه يه کتاب داره 400 صفحه شما برو بخوار بد بخون اگه نفهميدی ما ميگيم بهت رامبد جان توضيحی نداره اين مبحث ديگه اشن هست که چی بايد توش باشه اينجا قسمت آموزش نيست قسمت سؤال های الکی هم نيست اينشون يه سؤال کاملاً درست پرسيده که عجيب هست

مهمان
27-05-2005, 06:59
سلام
چگونگي ساختن job در SQL Server 2000 در صفحه asp که در زمان خاصي به افراد ميل زده شود
سطح: پيشرفته
کاربرد: زماني که تعداد زيادي آدرس اي ميل در يکي از ديتابيسهاي sql server داريد و مي خواهيد در روزهاي خاصي و در ساعت مشخصي به اين افراد ميل زده شود از اين اسکريپت استفاده مي شود.
لازم به ذکر است جهت ايجاد يک job حداقل نياز به ست کردن چهار آيتم مي باشد که عبارتند از:
sp_add_job
sp_add_jobstep
sp_add_jobschedule
sp_add_jobserver
جهت اطلاع از هر کدام از موارد مطروحه به books online خود sql server مراجعه نماييد.
پس از ست کردن چهار آيتم فوق به سراغ ديتابيس مورد نظر رفته و رکوردهاي تيبل خاصي را که در آن

آدرس اي ميل وجود دارند را در نظر مي گيريم.
کل کد به صورت زير مي باشد.
توجه داشته باشيد که بايد نام server نام ديتابيس و نام تيبل و نام فيلدها و نام کاربري و رمز کاربري

جهت اتصال به sql server را تنظيم نماييد.
ضمنا server شما بايد از امکان CDONT پشتيباني نمايد تا ارسال ميل با مشکل مواجه نشود.
سرورهاي قدرتمند حتما از اين آبجکت پشتيباني مي نمايند.
توجه داشته باشيد که من براي سهولت اصلاح کد محل قرار دادن متغيرها را به صورت زير تعيين کرده ام:
نام سرور را SERVERNAME
نام ديتابيس DATABASENAME
نام تيبل EmailTable
فيلدهاي موجود در تيبل: [From], [To], [Subject], [Body]
نام کاربري: USERID
رمز کاربري: PASSWORD
و اما کد مورد نظر:


برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید

Nesta
27-05-2005, 07:08
سلام متشکر از مطلب شما رامبد جان.

ooje_asman
27-05-2005, 07:19
با سلام خدمت رامبد جان می شه این برنامه رو از اول اول توضیح بدین لطفا

با سلام و تشکر از زحمات رفقا مخصوصا رامبد خان ، آقا منظور من این نیس که شما بیاین و کتال 400 صفحه ای رو مو به مو توضیح بدین من می گم اگه براتون ممکنه یه پروژه کوچک شروع بشه و پله پله بالا بره طوری که یه شخص بتونه با پی گیری آن بتونه یه برنامه بسازه چون فکر کنم اکثر برنامه های موجود در بازار نیز همشون تا یه حدی از امکانات این برنامه استفاده میکنن پس به نظرم یه پروژه طوری شروع بشه که فرد بتونه با اون، آخر سر یه برنامه کامل بسازه البته زحمتش پای رفقاست و تا نظر اساتید چی باشه

Nesta
27-05-2005, 07:25
زبان SQL تنها زبان استاندارد و جامع پياده‌سازي، مديريت، نگهداري و كار با بانكهاي اطلاعاتي مي‌باشد كه تقريباً توسط تمام بانكهاي اطلاعاتي كوچك و بزرگ مانند Access، SQL Server، Oracle و DB2 پشتيباني مي‌شود. طراحان و افرادي كه بنوعي با بانكهاي اطلاعاتي سروكار دارند و همچنين برنامه نويساني كه از اين بانكها استفاده مي‌كنند هركدام بايد تا اندازه‌‌اي با اين زبان آشنايي داشته باشند. اين مقاله كه در سه قسمت تهيه شده است مي‌كوشد تا مفاهيم زبان SQL را در قالب يك مثال كاربردي بيان كند. هرچند كه مفاهيم بكار رفته در اين مقاله در تمامي بانكهاي اطلاعاتي قابل پياده‌سازي مي‌باشند ولي مثالهاي ارائه شده در 2000 SQL Server مورد تست قرار گرفته‌اند.

بانك اطلاعاتي كه در اين مقاله بعنوان مثال مورد استفاده قرار گرفته است بانك اطلاعاتي يك آموزشگاه مي‌باشد كه شامل دو جدول بنامهاي teachers و students مي‌باشد. جدول اول اطلاعات اساتيد و جدول دوم اطلاعات دانشجويان را در خود نگه مي‌دارد. جدول اول داراي چهار فيلد زير مي‌باشد: name يا نام از نوع text، family يا فاميل از نوع text، age يا سن از نوع عدد، salary يا حقوق از نوع عدد.

جدول دانشجويان نيز شامل چهار فيلد مي‌باشد، سه فيلد اول آن مشابه سه فيلد اول جدول اساتيد مي‌باشد و فيلد چهارم آن عبارتست از GPA يا معدل كه يك فيلد عددي است.

زبان SQL داراي دستورات متنوع و نسبتاً زيادي مي‌باشد. به اين دستورات Clause نيز گفته مي‌شود. در اين مقاله و قسمتهاي بعدي آن تعدادي از مهمترين Clauseهاي زبان SQL مورد بررسي قرار مي‌گيرند.

1 – دستورهاي SELECT و FROM :

هدف نهايي از دادن انبوه اطلاعات به كامپيوتر، جستجو و يافتن اطلاعات مفيد مي‌باشد. به اين عمل يعني جستجوي اطلاعات در بانك اطلاعاتي Query نيز گفته مي‌شود. اكثر دستورات زبان SQL نيز در همين راستا مورد استفاده قرار مي‌گيرند. در اين بين مهمترين و پركاربردترين دستور را مي‌توان دستور SELECT قلمداد كرد.

اين دستور جهت انتخاب يك يا چند فيلد از يك يا چند جدول مختلف مورد استفاده قرار مي‌گيرد، فيلدهاي انتخاب شده پس از اجراي query روي صفحه نمايش داده خواهند شد.

بعنوان مثال اگر در بانك اطلاعاتي فرضي خودمان بخواهيم اسم و فاميل تمام دانشجويان را مشاهده كنيم بايد برنامه‌اي به شكل زير بنويسيم:

SELECT name, family
FROM students

در اين برنامه كه به زبان SQL استاندارد نوشته شده است از دو دستور SELECT و FROM استفاده شده است. دستور SELECT مشخص مي‌كند كه چه فيلدهايي از جدول بايد نمايش داده شوند و دستور FROM نيز مشخص كننده جدولي است كه قرار است اطلاعات از داخل آن استخراج شوند. حال اگر بخواهيم نام و فاميل تمام اساتيد را ببينيم برنامه بالا را بايد بصورت زير تغيير دهيم:

SELECT name, family
FROM teachers

همان طوري كه از مثال‌هاي بالا نيز مشخص است جلوي دستور SELECT نام فيلدهايي نوشته مي‌شوند كه قرار است نمايش داده شوند و بعنوان جداكننده نيز بايد از كاراكتر كاما استفاده كرد. در صورتي كه بخواهيم تمام فيلدهاي يك جدول را ببينيم مي‌توانيم بجاي نوشتن اسم تمام فيلدها فقط از يك كاراكتر ستاره استفاده كنيم. كاراكتر ستاره بمعني تمام فيلدهاي يك جدول مي‌باشد. مثلاً دو دستور زير با هم معادلند:

SELECT *
SELECT name, family, age, gpa

2 – دستور WHERE :

دستور SELECT همان طوري كه گفته شد جهت انتخاب و نمايش تعدادي از فيلدهاي جداول مورد استفاده قرار مي‌گيرد. در اين حالت تمام ركوردها نمايش داده خواهند شد، ولي در بيشتر موارد هدف از نوشتن Query نمايش ركوردهايي است كه داراي شرايط ويژه‌اي مي‌‌باشند مثلاً نمايش مشخصات اساتيدي كه بيش از پنجاه سال سن دارند. دستور WHERE براي گذاشتن يك يا چند شرط به دستور SELECT مورد استفاده قرار مي‌گيرد. با اضافه كردن شرط به دستور SELECT تعداد ركوردهاي خروجي (پاسخ) معمولاً محدودتر مي‌شود. بعنوان مثال اگر بخواهيم مشخصات اساتيدي كه بيش از چهل سال سن دارند را ببينيم بايد برنامه‌اي بصورت زير بنويسيم:

SELECT *
FROM teachers
WHERE age > 40

در اين برنامه شرط age > 40 با استفاده از دستور WHERE به Query اضافه شده و باعث شده است تا فقط مشخصات اساتيدي نمايش داده شوند كه در اين شرط صدق مي‌كنند يعني بيش از چهل سال سن دارند.

حال اگر بخواهيم مشخصات دانشجوياني را كه نام آنها علي مي‌باشد و سن آنها نيز كمتر از پانزده سال است را ببينيم بايد Query زير را اجرا كنيم:

SELECT *
FROM students
WHERE age < 15 AND name = 'ali'

در مثال بالا دو مطلب جديد وجود دارد نخست آنكه در زبان SQL رشته متني را بايد داخل كوتيشن (‘) قرارداد. بنابراين براي معرفي كلمه‌اي بنام علي بايد آنرا بصورت ‘ali’ نوشت، زيرا در اين حالت اين كلمه يك ثابت رشته‌اي (متني) بحساب مي‌آيد. نكته ديگر آنكه مي‌توان شرطهاي مختلف را توسط AND، OR و NOT با همديگر ادغام كرده و شرطهاي پيچيده‌تري را بدست آورد. AND، OR و NOT هر سه از كلمات كليدي زبان SQL مي‌باشند. بعنوان يك مثال ديگر فرض كنيد مي‌خواهيم مشخصات تمام دانشجوياني را كه نام آنها، علي يا رضا نباشند را پيدا كنيم، برنامه‌اي كه اين Query را انجام مي‌دهد بصورت زير مي‌باشد:

SELECT *
FROM students
WHERE name NOT IN ('ali', 'reza')

در صورتي كه NOT را از برنامه بالا حذف كنيم مشخصات تمام دانشجوياني كه نام آنها علي يا رضا مي‌باشند نمايش داده خواهد شد.

در اين برنامه نيز يك كلمه كليدي جديد وجود دارد: IN كه براي تست عضويت در يك مجموعه بكار مي‌رود. مجموعه‌اي كه بادستور IN بكار مي‌رود مي‌تواند دهها عضو داشته باشد و نوع اعضا نيز مي‌تواند رشته‌اي، عددي يا ... باشد. البته واضح است كه تمام اعضا بايد هم نوع باشند.

حال بعنوان يك مثال پيشرفته‌تر مي‌خواهيم مشخصات دانشجوياني را ببينيم كه اسم فاميل آنها به ‘ زاده’ ختم مي‌شود مانند عليزاده، محمد زاده و ... براي اين منظور بايد Query زير را نوشته و اجرا كنيم:

SELECT *
FROM family LIKE '% zadeh'

كاربراني كه با Access كار مي‌كنند بايد سطر آخر را به صورت زير تغيير دهند:

WHERE family LIKE '*zadeh'

در اين مثال از Wildcardها استفاده شده است كه قبلاً با مفهوم آن در DOS و Windows يا حتي Unix آشنا شده‌ايم (ls a*) . در Wildcard ،SQL هايي به شرح زير وجود دارند:

% (در Access از * استفاده كنيد): اين Wild card نشانگر هر تعدادي از كاراكترها (هر كاراكتري) مي‌باشد.

- (در Access از ? استفاده كنيد): اين Wildcard نشانگر يك كاراكتر مي‌باشد كه اين كاراكتر مي‌تواند هر كدام از كاراكترهاي مجاز كامپيوتر باشد.

جهت جستجو كردن فيلدهايي كه داراي يك الگوي (Pattern) خاصي هستند بايد از دستور LIKE و Wildcardها استفاده كرد. در مثال زير نام و سن تمام اساتيدي كه اسم آنها با Pe شروع مي‌شود، نمايش داده خواهد شد.

SELECT name, age
FROM teachers
WHERE name LIKE 'Pe%'

بنابراين مشخصات افرادي كه نام آنها مثلاً پدرام يا پيمان باشد در خروجي ليست خواهد شد.

3 – دستور ORDERBY :

دستور ORDERBY جهت Sort كردن ركوردهاي نمايش داده شده مورد استفاده قرار مي‌گيرد. با اين دستور مي‌توان مشخص كرد كه ركوردهايي كه قرار است نمايش داده شوند برحسب كدام فيلد بايد مرتب شوند. بعنوان مثال براي مشاهده كردن مشخصات اساتيدي كه سن آنها بيشتر از 29 سال مي‌باشد و در ضمن ليست خروجي بترتيب اسم فاميل نيز مرتب شده باشد بايد Query زير را اجرا كرد.

SELECT *
FROM teachers
ORDERBY family

در اين حالت افراد بترتيب اسم فاميل خود ليست خواهند شد. (از A تا Z) در صورتي كه بخواهيم ترتيب Sort شدن برعكس شود (از Z تا A) مي‌توان پس از دستور ORDERBY از كلمه كليدي DESC استفاده كرد، مانند مثال زير

SELECT *
FROM teachers
ORDERBY DESC name

در اين مثال Sort شدن بترتيب اسم و نه بترتيب فاميل انجام مي‌گيرد.

براي دستور ORDERBY مي‌توان چند فيلد تعريف كرد، در اين صورت اين دستور عمل Sort كردن را با در نظرگرفتن اولين فيلد انجام خواهد داد در صورتي كه چند ركورد داراي مقدار مشابهي در اين فيلد باشند ملاك مرتب سازي آنها فيلد دومي خواهد بود كه در دستور ORDERBY ذكر شده است، در صورتي كه اين فيلد نيز داراي مقادير مشابهي باشد ملاك تصميم‌ گيري فيلد سوم خواهد بود والي آخر.

بعنوان مثال در Query زير نام اساتيدي كه بيش از 30 سال دارند برحسب فاميل آنها مرتب مي‌شود در صورتي كه چند استاد داراي اسم فاميل يكساني باشند ملاك مرتب شدن، اسم كوچك آنها خواهد بود.

SELECT *
FROM teachers
WHERE age > 30
ORDERBY family, name

4 – استفاده از توابع:

در دستور SELECT علاوه بر تعريف فيلدها مي‌توان از عبارتهاي رياضي و يا توابع استاندارد SQL نيز استفاده كرد.

بعنوان مثال اگر ماليات بردرآمد پنج درصد باشد Query زير نام اساتيد و مالياتي را كه هر كدام مي‌پردازند را مشخص مي‌كند.

SELECT family, name, salary*5/100
FROM teachers

علاوه بر عبارتهاي رياضي مي‌توان از توابع استاندارد SQL نيز استفاده كرد، تعدادي از اين توابع عبارتند از:

تابع COUNT : تعداد فيلدها را برمي‌گرداند.

تابع SUM : مجموع يك فيلد عددي را برمي‌گرداند.

تابع AVG : ميانگين يك فيلد عددي را برمي‌گرداند.

تابع MIN : مينيمم يك فيلد عددي را برمي‌گرداند.

تابع MAX : ماكزيمم يك فيلد عددي را برمي‌گرداند.

بعنوان مثال اگر بخواهيم تعداد اساتيد و مجموع حقوقهايي را كه به آنها پرداخت شده است را ببينيم مي‌توانيم از Query زير استفاده بكنيم.

SELECT COUNT (name), SUM (Salary)
FROM teachers

5 – Queryهاي چند جدولي:

تمام Queryهايي كه تاكنون مشاهده كرديد، Queryهاي تك جدولي بودند بدين معني كه در هر Query فقط اطلاعات يك جدول مورد جستجو قرار مي‌گرفت. در SQL امكان نوشتن Queryهاي چند جدولي نيز وجود دارد. در اين حالت اطلاعات چند جدول بطور همزمان مورد جستجو قرار مي‌گيرد و حتي امكان مقايسه فيلدهايي از يك جدول با فيلدهايي از جدول ديگر نيز وجود دارد. اگر در بين جداولي كه در Query شركت داده مي‌شوند فيلدهاي هم نام وجود داشته باشد بايد نام آن فيلدها را Fully qualified كرد بدين معني كه ابتدا اسم جدول و سپس اسم فيلد را ذكر كرد. بين اسم جدول و اسم فيلد نيز بايد از يك كاراكتر نقطه (‘.’) استفاده كرد.

بعنوان مثال اگر بخواهيم ليست اساتيد و دانشجوياني كه داراي ارتباط فاميلي هستند را ببينيم مي‌توانيم از Query زير استفاده بكنيم:

SELECT *
FROM students, teachers
WHERE students.family = teachers. Family

و يا اگر بخواهيم ليست اساتيدي را مشاهده كنيم كه سن آنها از سن برخي از دانشجويان كمتر است، مي‌توانيم Query زير را اجرا كنيم:

SELECT teachers.family, teachers.name
FROM students, teachers
WHERE teachers.age < students.age

6 – كلام آخر:

كلام آخر اينكه زبان SQL برخلاف زبانهايي مانند C يا C++ يك زبان Case Sensitive نيست بدين معني كه به بزرگ يا كوچك بودن حروف حساس نمي‌باشد. بنابراين به راحتي مي‌‌توان دستورات و كلمات كليدي آنرا در هر برنامه‌اي با حروف كوچك يا بزرگ تايپ كرد.

Nesta
27-05-2005, 07:25
يك نقص امنيتي در الگوريتم پنهان سازي مورد استفاده در پنهان كردن اسم رمز و Login ID در Microsoft Enterprise Manager for SQL Server 7.0 وجود دارد. اين مشكل زماني رخ مي‌دهد كه بخواهيد SQL Server جديدي را در Enterprise Manager نصب ‌كنيد يا SQL server نصب شده‌اي را ويرايش ‌كنيد (منظور زماني است كه برخي مشخصه‌هاي آن تغيير مي‌دهيد). اگر SQL Server ، Login name به جاي يك Domain ، User name ويندوز بكار رود و checkbox عنوان "Alway prompt for login name and password" ست نشده باشد،‌ LoginID و اسم رمز به صورتي ضعيف پنهان شده و در رجيستري ذخيره مي‌شود.

هنگامي كه يك (database Administrator)DBA به داخل يك workstation با يك log ، Profile مي‌شود LoginID و اسم رمز، هر دو در كليد رجيستري ذخيره مي‌شوند، اين اطلاعات به عنوان يك فايل با نام NTUSER.DAT (در ويندوز NT) يا USER.DAT (در ويندوز 95 يا ويندوز 98) زماني كه كاربر logoff مي‌كند ذخيره مي‌شود. فرد متخاصم مي‌تواند اين فايل را در يك ويرايشگر متن باز كرده و DBA ، loginID و اسم رمز پنهان شده را ببينيد. فرد متخاصم مي‌تواند اسم رمز و login ID رمز شده پنهان شده را برگردانده و loginID و اسم رمز را بدست آورد. وجود اين مشكل امنيتي به متخاصمين محلي و راه دور اين اجازه را مي‌دهد كه اسم رمز Administrator سيستم را بدست آورده و كنترل كاملي روي پايگاه داده روي سرور داشته باشند. اين مشكل امنيتي در Microsoft Enterprise Manager for SQL server 7.0 وجود دارد. سيستم پنهان سازي كه براي پنهان كردن اسم رمز و SQL server ، LoginID نصب شده بكار مي‌رود، قابل كشف است. روش پنهان سازي از جانشيني الفبايي استفاده مي‌كند و هركدام از كاراكترهاي Unicode در اسم رمز با دو بايت متناسب با موقعيتشان در رشته، XOR شده‌اند. اگر checkbox با عنوان “Always prompt for login name and password” هنگامي كه SQL server نصب مي‌شود ست نشده باشد، LoginID و اسم رمز به صورت ضعيفي در رجيستري در قسمت :

--------------------------------------

[HKEY_CURRENT_USER\SOFTWARE\Microsoft\MSSQLServer\S QLEW\Registered Server X]

--------------------------------------

ذخيره مي‌شود. اطلاعات ذخيره شده در HKEY_CURRENT_USER زماني در دسترس است كه كاربر در حال حاضر log شده باشد در اين حال زماني كه كاربر ويندوز NT به سيستم log مي‌شود يك كپي متفاوت از HKEY_URRENT_USER لود مي‌شود و هنگامي كه كاربر Logoff مي‌كند محتويات HKEY_URRENT_USER در فايل NTUSER.DAT يا USER.DAT ذخيره مي‌شود و اين فايل‌ها را مي‌توان در Notepad ويندوز باز كرد و loginID و اسم رمز را براحتي در آن ديد اگر DBA از يك workstation ديگري، به سيستم log كند، فايل NTUSER.DAT روي همان workstation كه كاربر از طريق آن به سيستم log شده است ذخيره مي‌شود.

براي حل اين مشكل امنيتي و استفاده مطمئن از SQL server، مايكروسافت پيشنهاد كرده كه از Windows Integrated security استفاده شود زيرا در مد Integrated security (امنيت يكپارچه)، اسم رمزها هيچگاه ذخيره نمي‌شوند.

اگر SQL server ، LoginID براي Logging به يك سرور در Enterprise Manager تعيين شده باشد، مايكرسافت پيشنهاد مي‌كند كه از انتخاب “Always Prompt for Login name and password" براي جلوگيري ذخيره اسم رمزها در رجيستري استفاده كنيد.

Nesta
27-05-2005, 07:26
شاخصهاي يك جدول مي‌توانند به شما در دسترسي به يك يا چند سطر از داده‌ها كمك كنند. داشتن يك شاخص خوب براي پرس و جوي (query) شما يكي از بهترين راههاي بهبود بخشيدن به عملكرد است. هنگامي كه پرس و جوي شما سعي دريافتن تنها تعداد محدودي سطر از يك جدول بزرگ دارد،‌وجود يا عدم وجود يك شاخص خوب و مفيد مي‌تواند تاثير چشمگيري در تفاوت عملكرد داشته باشد. هنگام تنظيم پرس و جوهايي كه جداول گوناگوني دارند (مانند پيوند)، شاخصها مي‌توانند بطور موثري به سرويس‌دهنده SQL دريافتن سطرهاي موردنظر از بين جدولها كمك كنند.

بهينه ساز پرس و جوي سرويس دهنده SQL مي‌تواند براي اجراي پيوندها از ميان 3 استراتژي يكي را انتخاب كند: پيوند حلقه‌اي تودرتو (nested-loop)، پيوند ادغامي (merge) و پيوند hash، در اين مقاله به شرح دو استراتژي اول يعني حلقه‌اي تودرتو و ادغامي مي‌پردازيم. در هر روش، جدولهايي را كه مي‌خواهيد پيوند دهيد (يا زير مجموعه‌هايي از آنها كه با شرط WHERE محدود كرده‌ايد) ورودي‌هاي پيوند هستند. اگر پرس و جوي شما علاوه بر پيوند، شرط WHERE را نيز شامل شود، سرويس دهنده SQL ممكن است قبل از يافتن سطرهاي موردنظر در دومين جدول شرط WHERE را بكار ببرد. بعنوان مثال پرس و جوي 1 از بانك اطلاعاتي Northwind را در نظر بگيريد.

-- Query 1:
SELECT LastName, FirstName, OrderID, OrderDate
FROM Employees e JOIN Orders o
ON e.EmployeeID = o.EmployeeID

اين پيوند تمام سفارشات را از جدول سفارشها باز مي‌گرداند و همچنين براي هر يك از آنها، FirstName، LastName كارمندي را كه به آن OrderID و OrderDate مربوط مي‌شود را نيز باز مي‌گرداند.

در پرس و جوي 1 سرويس دهنده SQL تمام سطرها را در جدول كارمندان و سفارشات امتحان مي‌كند و ورودي‌هاي پيوند تمام سطرهاي جدولها هستند. بهرحال، طبق آنچه كه پرس و جوي 2 نشان مي‌دهد، اگر شما عبارت SELECT را با دو شرط WHERE تعريف كنيد، وروديهاي پيوند ديگر تمام سطرهاي جدولها نيستند.

-- Query 2:
SELECT LastName, FirstName, OrderID, OrderDate
FROM Employees e JOIN Orders o
ON e.EmployeeID = o.EmployeeID
WHERE OrderDate < '1996-12-01' AND LastName < 'D'

وروديهاي پيوند در پرس و جوي 2، بسيار كوچكتر از پرس و جوي 1 هستند. به جاي پيوند 9 سطر از جدول كارمندان با 830 سطر از جدول سفارشات، سرويس دهنده SQL بايد تنها 2 سطر از جدول كارمندان را با 121 سطر از جدول سفارشات پيوند دهد. بهينه ساز پرس و جو با وجود تعداد محدودي از سطرهاي ورودي غالباً استراتژي پيوند متفاوتي را در مقايسه با زماني كه وروديهاي پيوند بيشتر هستند برمي‌گزيند و همچنين ممكن است جدولها را به سبك متفاوتي پيوند دهد. به همان اندازه كه تصميمات استراتژي بهينه ساز مهم هستند اندازه جدولها نيز حائز اهميت است.

حلقه‌هاي تودرتو

حتي اگر پرس وجوي شما بيش از 2 جدول را پيوند دهد، سرويس دهنده SQL عمل پيوند را از طريق پيوند تنها دو ورودي در يك زمان اجرا مي‌كند و هر پيوند در يك پرس و جو ممكن است از استراتژي پيوند متفاوتي استفاده كند. آسانترين نوع پيوند – و نوعي از پيوند كه اكثر افراد هنگام عمليات پيوند بدان فكر مي‌كنند – پيوند حلقه تودرتوست مي‌توانيد تصور كنيد كه سرويس دهنده SQL روي دو ورودي عمل مي‌كند حتي اگر آنها آرايه‌هايي در يك زبان پيشرفته مانند C يا Basic باشند. سرويس دهنده SQL هر سطر يك ورودي را با تمام سطرهاي ورودي ديگر مقايسه مي‌كند تا تطابق بين سطرها را بيابد.

پرس و جوي 1 سعي دريافتن سطرهايي دارد كه با ستون EmployeeID تطبيق داشته باشد. بنابراين با استراتژي پيوند حلقه تودرتو، سرويس دهنده SQL بايد تمام مقادير EmployeeID در يك جدول را با تمام مقادير EmployeeID در جدول ديگر مقايسه كند.

بدترين قسمت سناريو براي يك پيوند حلقه تودرتو زماني است كه هيچ شاخصي نتواند به سرويس دهنده SQL دريافتن سطرهاي منطبق در بين وروديها و همچنين يافتن سطرهايي كه در هر شرط WHERE صدق مي‌كند، كمك نمايد. در ين حالت، وروديها كل سطرهاي جدولها هستند. بهينه ساز پرس و جو جدولي را بعنوان جدول خارجي انتخاب مي‌كند و در ابتدا به سطرهاي آن دستيابي مي‌يابد. بياييد فرض كنيم كه جدول خارجي داراي P1 صفحه و R1 سطر باشد. دومين جدول كه جدول داخلي است P2 صفحه دارد. سرويس دهنده SQL بايد تمام صفحات را از جدول خارجي بخواند؛ و براي هر سطر تعريف شده در هر صفحه بايد تمام صفحات را از جدول داخلي بخواند. براي يافتن تعداد صفحاتي كه سرويس دهنده SQL براي خواندن و ارائه نتيجه نياز دارد، مي‌توانيد از فرمول زير استفاده كنيد:

P1 + R1 * P2

حتي اگر جدولها نسبتاً كوچك باشند، عدد حاصله از صفحات خوانده شده به سرعت بزرگ مي‌شود. در مورد يك جدول خارجي با تنها 200 صفحه و 4000 سطر (براي مثال 20 سطر براي هر صفحه) و يك جدول داخلي با 100 صفحه، نتيجه رقمي كاملاً بزرگ است. جدولهايي با 100 يا 200 صفحه جدولهايي نيستند كه بطور غيرمعمول بزرگ باشند، اما براي پردازش پيوند در صورتي كه جدولها شاخصهاي مفيدي نداشته باشند، سرويس دهنده SQL نياز به دستيابي به بيش از 400,000 صفحه خواهد داشت.

شاخصها مي‌توانند در بهبود عملكرد يك پيوند حلقه تودرتو به طرق مختلف نقش داشته باشند. بزرگترين حسن اين شاخصها اغلب زماني است كه شما يك شاخص كلاستري روي ستون پيوند يكي از جدولها داشته باشيد. وجود يك شاخص كلاستري روي ستون پيوند غالباً مشخص مي‌كند كه سرويس دهنده SQL چه جدولي را بعنوان جدول داخلي انتخاب مي‌كند. اگر جدول داخلي داراي شاخص كلاستري باشد، سرويس دهنده SQL نياز به جستجو در ميان كل سطرهاي آن جدول را ندارد. شاخص كلاستري، سرويس دهنده SQL را مستقيماً به سوي سطرهايي در جدول داخلي هدايت مي‌كند كه داراي مقدار ستون پيوند بوده كه سطرهاي جاري در جدول خارجي را تطبيق مي‌دهد. بنابراين در آن فرمول، به جاي عبارت R1 ´ P2 كه نشان مي‌دهد سرويس دهنده SQL به تمام P2 صفحه دستيابي پيدا مي‌كند، مي‌توانيد P2 را با دستيابي 2 يا 3 صفحه‌اي جايگزين كنيد بسته به اينكه شاخص كلاستري چند Level دارد. بنابراين در مورد مثالي با 200 صفحه و 400 سطر در جدول خارجي و 100 صفحه در جدول داخلي نتيجه 3*4000+200 يا 200،12 صفحه خوانده شده است – يك پيشرفت بزرگ بالاي 400,000 صفحه مي‌باشد.

هنوز هم آن 4000 سطر در محاسبه نتيجه را بزرگتر از حد انتظار خواهد كرد. در اين حالت، تمامي 4000 سطر در جدول خارجي بخشي از نتيجه هستند كه موجب 4000 بار رجوع به جدول داخلي مي‌شود. يك راه ديگر براي كاهش تعداد صفحات بدست آمده كاهش اندازه وروديهاي خارجي است. علاوه بر كنترل شاخص كلاستري روي ستون پيوند، ابتدا بهينه ساز سعي مي‌كند جدولها را با وروديهاي كوچكتر پيوند دهد. در پرس و جوي 1، جدول كارمندان داراي يك شاخص كلاستري روي ستون پيوند يعني EmployeeID هستند اما اين جدول نيز بطور نمايشي كوچكتر از جدول سفارشات است. جدول كارمندان تنها 9 سطر دارد و جدول سفارشات 830 سطر. در پرس و جوي 1، اگر بهينه ساز يك پيوند حلقه تودرتو را انتخاب كند، از جدول كوچكتر كارمندان به عنوان ورودي خارجي استفاده مي‌كند بگونه‌اي كه تنها 9 بار به جدول سفارشات رجوع خواهد داشت.

اگر شما داراي شرط WHERE باشيد كه جدول خارجي را شامل مي‌شود، تعداد سطرهاي تعريف شده پايين مي‌آيد و سرويس دهنده SQL كمتر نياز به مراجعه به جدول داخلي را خواهد داشت. اگر پرس و جوي 1 را طوري تغيير دهيد كه شامل يك شرط WHERE در جدول سفارشات باشد، همانگونه كه در پرس و جوي 3 نشان داده شده، طرح پرس و جو تغيير مي‌كند.

-- Query 3:
SELECT LastName, FirstName, OrderID, OrderDate
FROM Employees e JOIN Orders o
ON e.EmployeeID = o.EmployeeID
WHERE OrderDate < '1996-12-01'

حالا، تنها 121 سطر در جدول سفارشات بخشي از نتيجه هستند، آن جدول كوچكتر كه با شاخص كلاستري روي ستون پيوند جدول كارمندان تركيب شده اين مفهوم را مي‌رساند كه بهينه ساز حالا جدول كارمندان را به عنوان جدول داخلي انتخاب مي‌كند. سرويس دهنده SQL از پيوند حلقه تودرتو استفاده خواهد كرد چرا كه شاخص كلاستري باعث مي‌شود سرويس دهنده SQL سريعاً سطرهاي منطبق شده را در جدول داخلي بيابد.

FIGURE 1: Query plan for Query 3
|..Nested Loops(Inner Join, OUTER REFERENCES:([o].[EmployeeID]))
|..Clustered Index Scan(OBJECT:([northwind].[dbo].[Orders].[PK_Orders]
AS [o]),
WHERE:([o].[OrderDate] < 'Dec 1 1996 12:00AM'))
|..Clusterd Index
Seek(OBJECT:([northwind].[dbo].[Employees].[PK_Employees] AS [e]),
SEEK:([e].[EmployeeID]=[o].[EmployeeID]) ORDERED FORWARD)

شكل 1 طرح پرس و جو را در مورد پرس و جوي 3 نشان مي‌دهد. اولين خط اين طرح نوع پيوند (حلقه تودرتو) را نشان مي‌دهد و مشخص مي‌كند كه جدول خارجي ستون EmployeeID را ارجاع خواهد داد.

اسكن شاخص كلاستري در جدول خارجي شبيه اسكن يك جدول است زيرا هيچيك از شاخصهاي موجود نمي‌تواند دستيابي به جدول خارجي را سرعت ببخشد. شرط WHERE در ستون OrdrerDate تعداد سطرهاي برگردانده شده و تعداد دفعاتي كه سرويس دهنده SQL بايد به جدول داخلي دستيابي داشته باشد تا تعيين كند كداميك مقدار
OrderDate قابل قبولي دارند. در نهايت، طرح پرس و جو نشان مي‌دهد كه سرويس دهنده SQL از يك شاخص كلاستري براي جستجوي جدول داخلي استفاده مي‌كند زيرا اين شاخص روي ستوني است كه سرويس دهنده SQL براي يافتن سطرهاي منطبق استفاده مي‌كند.

چنانچه قبلاً ذكر شد شاخص در ستون OrderDate چيز خوبي است اما عملكرد پرس و جو را تقريباً به يك شاخص كلاستري روي ستون پيوند بهبود نخواهد بخشيد. يك شاخص مفيد در پارامتر جستجو در جدول خارجي بدين معناست كه سرويس دهنده SQL نبايد به تمام صفحات جدول خارجي رجوع نمايد، بنابراين،‌ مقدار P1 كاهش مي‌يابد. باتوجه به اينكه مقدار P1 نسبت به مقدار دومين عبارت،‌ P2 R1، كوچكتر است، بنابراين كاهش مقدار P1 فقط موجب بهبودي كمتر عملكرد مي‌گردد. شاخص جدول خارجي تعداد دفعاتي كه سرويس دهنده SQL بايد به جدول داخلي رجوع كند را كاهش نمي‌دهد زيرا سرويس دهنده SQL هنوز بايد بازاي هر سطر تعريف شده در جدول خارجي به جدول داخلي رجوع كند. شما مي‌توانيد انتخاب بهينه‌ساز از پيوند حلقه تودرتو را اينگونه تعميم دهيد: در صورتي كه يكي از وروديهاي پيوند بسيار كوچكتر از ديگري و ورودي بزرگتر داراي يك شاخص كلاستري روي ستون پيوند باشد، بهينه ساز اغلب پيوند حلقه تودرتو را برمي‌گزيند.

ادغام

در پيوند حلقه تودرتو، شاخص ستون پيوند در مورد جدول خارجي بي‌فايده است. بهرحال، زماني كه شما پرس و جوها و جداول را تنظيم مي‌كنيد، ممكن است هميشه ندانيد كه كدام جدول داخلي و كدام خارجي است، بنابراين بايد در هر دو جدول ورودي شاخصهاي كلاستري را روي ستونهاي پيوند ايجاد كرد. زماني كه هر دو وروديهاي پيوند روي ستون پيوند مرتب سازي مي‌شوند، سرويس دهنده SQL مي‌تواند از پيوند ادغامي استفاده كند، درست مانند موردي كه هر دو جدول داراي شاخصهاي كلاستري روي ستون پيوند باشند.پيوند ادغامي را مي‌توان همچون تركيب دويست مرتب سازي شده از مقادير تصور كرد. فرض كنيد داراي دو سري از اطلاعات پيمانكاري هستيد. يك سري شامل قراردادهاي مهم مي‌باشد كه هر پيمانكاري آن را امضا كرده است و دومين سري توصيف هريك از پروژه‌هايي است كه پيمانكار بر روي آن كار مي‌كند بنابراين، شما اساساً نياز به يك پل ارتباطي ميان اين دو سري اطلاعات داريد.پرس و جوي 1 را در نظر بگيريد: اگر جدول كارمندان و جدول سفارشات در ستون EmployeeID شاخصهاي كلاستري داشته باشند، سرويس دهنده SQL مي‌تواند پيوند ادغامي را اجرا كند. شبه كد مربوطه در مورد اجراي ادغامي سرويس دهنده SQL چيزي شبيه اين عبارات خواهد بود:

GET one Orders row and one Employees row
DO (until one input is empty);
IF EmployeeID values are equal
Return values from both rows
GET next Orders row
ELSE IF Orders.EmployeeID <> Employees.EmployeeID
GET next Employees row
ELSE GET next Orders row


بهينه ساز پرس و جو معمولاً استراتژي پيوند ادغامي را زماني انتخاب مي كند كه هر دو وروديها قبلاً در ستون پيوند مرتب شده باشند. اگر هر دو ورودي قبلاً مرتب شده باشند، در صورتي كه پيوند يك به چند باشد استفاده از I/O كمتري براي پردازش پيوند ادغامي ضروريست. پيوند ادغامي چند به چند (M:N) به جاي كنار گذاشتن سطرها كه معمولاً انجام مي‌دهد، آنها را در يك جدول موقتي ذخيره مي‌كند. اگر داده‌ها شامل مقادير تكراري از هر دو ورودي باشند، هنگامي كه سرويس دهنده SQL هر مقدار تكراري را از اولين ورودي پردازش مي‌كند، دومين ورودي بايد به ابتداي مقادير تكراري در جدول موقت بازگردد. بهرحال، در اكثر موارد، سرويس دهنده SQL از پيوند ادغامي استفاده نخواهد كرد مگر اينكه حداقل يكي از ستونهاي پيوند Unique باشد.در اينجا مثالي از پيوند دو جدول يكي با شاخص و ديگري بدون شاخص Unique آورده شده است.



LISTING 1: Joins Two Tables With and Without Unique Index

-- Copy the two tables
SELECT * INTO o1 FROM orders
SELECT * INTO od1 FROM [order details]

-- Create the indexes.
CREATE CLUSTERED INDEX orders_index
ON o1(orderID)
CREATE CLUSTERED INDEX OD_index
ON od1(orderID)

-- Look at the query plan for the query.
SELECT * FROM o1 JOIN od1
ON o1.orderID = od1.orderID

-- Now recreate the clustered index on o1 as unique.
CREATE UNIQUE CLUSTERED INDEX orders_index ON o1(orderID)
WITH DROP_EXISTING

-- Now Look at the query plan for the query.
SELECT * FROM o1 JOIN od1 ON o1.orderID = od1.orderID

LISTING 2: Modified Listing 1

SELECT * INTO o2 FROM orders

SELECT * INTO od2 FROM [order details]

CREATE UNIQUE CLUSTERED INDEX orders_index ON o2(orderID)
CREATE INDEX OD_index ON od2(orderID)

-- Check the query plan to see the sort operation before
-- the merge join:
SELECT * FROM o2 JOIN od2
ON o2.orderID = od2.orderID



ليست 1 كپي‌هايي از جدول سفارشات و جدول جزئيات سفارشات در بانك اطلاعاتي Northwind ايجاد مي‌كند و يك شاخص كلاستري در OrderID هر دو جدول مي‌سازد. زماني كه شما ابتداً اين جدولها را پيوند مي‌دهيد و طرح پرس و جو را به نمايش مي‌گذاريد، خواهيد ديد كه سرويس دهنده SQL پيوند حلقه تودرتو را انتخاب مي‌كند. اگرچه ستون OrderID در جدول سفارشات Unique است، اما در صورتي كه Unique بودن را در تعريف شاخص مشخص نكنيد، بهينه ساز متوجه نخواهد شد كه مقادير كليدي Unique هستند. بنابراين هنگامي كه مجدداً شاخص كلاستري را در جدول سفارشات مي‌سازيد و مشخص كنيد كه آن شاخص بايد Unique باشد، طرح پرس و جوي اصلاح شده نشان مي‌دهد كه سرويس دهنده SQL از يك پيوند ادغامي استفاده مي‌كند. در برخي از حالتها، بهينه ساز سرويس دهنده SQL ممكن است به دليل به صرفه بودن تصميم بگيرد يكي از وروديها را قبل از پيوند مرتب كند و بعد پيوند ادغامي را اجرا نمايد. اگر ليست 1 را كمي تغيير دهيد به گونه‌اي كه شاخص اوليه كه در جدول جزئيات سفارشات ساخته مي‌شود كلاستري نباشد، طبق آنچه كه ليست 2 نمايش مي‌دهد، طرح پرس و جو عمل مرتب سازي را قبل از پيوند ادغامي نشان مي‌دهد.

جدولهايتان را بشناسيد

معمولاً، بهينه ساز پرس و جو تعيين مي‌كند كه سرويس دهنده SQL چه نوع پيوندي را استفاده خواهد كرد. شما مي‌توانيد پرس و جوي پيوند خود را نوشته و انتخاب استراتژي را به عهده SQL بگذاريد. بهرحال، دانستن نحوه اجراي پيوندها در سرويس دهنده SQL مي‌تواند انتخاب شما در مورد شاخصهاي مفيدتر كمك كند. بهينه ساز معمولاً در صورتي كه يكي از وروديهاي پيوند در مقايسه با ورودي ديگري كوچكتر و ورودي بزرگتر داراي يك شاخص كلاستري روي ستون پيوند باشد، از پيوند حلقه تودرتو استفاده مي‌كند. اگر هر دو ورودي در ستون پيوند مرتب شده باشند و بخصوص يكي از وروديها داراي شاخص كلاستري unique باشد نوع پيوند به احتمال زياد ادغامي خواهد بود.

هر دو پيوند ادغامي و حلقه تودرتو نياز به شاخصهاي مناسب در جدولها دارند. بهرحال، اگر برنامه كاربردي شما باعث شود كه كاربرها پرس و جوهاي ويژه بسازند، ممكن است در ابتدا ندانيد كه بهترين ستون براي شاخصها كدام است. سومين نوع پيوند، پيوند hash است كه باعث مي‌شود سرويس دهنده SQL به يك عملكرد پيوند بسيار خوب دست بيابد حتي زماني كه جداول شما از شاخصهاي مفيدي برخوردار نباشند.

Masoud.ebi
03-08-2005, 07:56
دوستان سلام
آقا میخواستم کار با SQL Server رو یاد بگیرم
کسی میتونه کمکم کنه ممنون میشم
یه دیتابیس پارادوکس دارم میخوام تبدیلش کنم به SQL و ازش استفاده کنم به صورت شبکه
البته کارلوس جان برنامه ای جهت تبدیل پارادوکس به اس کیو ال معرفی کردن
حالا از دوستان تقاضا دارم که جهت شبکه نمودنش کمکم کنن

با تشکر

Nesta
03-08-2005, 14:57
سلام مسعود جان به نظرم اگه کتاب برای شبکه کردن بخری بهتر هست چون که خیلی‌ آسان نیست .حالا من در این مورد باز اطلاعات برای شما کسب می‌کنم که چه می‌شه کرد.

Masoud.ebi
06-08-2005, 09:03
کارلوس جان دستت درد نکنه

خلاصه ازت ممنون میشم اگه کمکم کنی

Nesta
06-08-2005, 21:07
سلام مسعود جان جهت شبکه کردنش رو من درست نفهمیدم یعنی‌ چی‌ می‌شه دوست من کمی‌ توضیح بدی میخای چی‌ کار کنی‌ آخه بانک اطلاعاتی‌ رو شبکه کنی‌ که مانی‌ نمیده میتونی‌ در سرور شبکه نصب کنی‌ یا رو سایت اپلد کنی‌ جهت استفاده برنامه .حالا نمیدونم باز توضیح دقیق بده . :D :D

Masoud.ebi
08-08-2005, 17:00
دوست عزیز سلام
منظورم از شبکه کردن اینه که بانک اطلاعاتی رو رو یه کامپیوتر قرار بدم و همزمان چند تا کامپیوتر بتونن به بانک اطلاعاتی متصل بشن جون میدونی که در حالت عادی بانک اطلاعاتی پارادوکس اجازه بیشتر از یک اتصال همزمان رو نمیده
یه سوال داشتم آیا میشه کاری کرد که بانک اطلاعاتی پارادوکس میزبان بیش از یک اتصال باشه یعنی چند تا سیستم بتونن بهش وصل شن چونکه توی حالت عادی زمانیکه یه کانکشن ایجاد میشه یه فایل با پسوند Lock ایجاد میشه و اجازه دسترسی سایر اتصالات رو لغو میکنه
آیا راهی وجود داره امیدوارم تونسته باشم منظورم رو رسونده باشم ممنمن میشم کمکم کنید
با تشکر

bithiah
11-08-2005, 08:12
يه مشكلي دارم:
از طريق ويژوال بيسيك داده هاي بزبون فارسي رو توي بانك SQL server ذخيره كردم ولي موقع بازيابي بجاي همه كاراكترها علامت سوال مي زنه. در حاليكه اگه همونا رو مستقيم توي SQL بزنم درست نشون ميده. چي كار كنم؟

ممنون مي شم اگه منوراهنمايي كنين.

Masoud.ebi
17-08-2005, 07:44
بابا یکی نیست جواب ما رو بده
الان درست 11 روز از آخرین پست میگذره یکی نیست که جواب بده
بابا اگه اینجوریه در این تاپیک رو تخته کنین دیگه
واقعا هم وقتی این تاپیک رو با سایر تاپیک های برنامه نویسی مقایسه میکنم میبینم اصلا پیشرفتی نداشته

Nesta
17-08-2005, 13:19
سلام مسعود جان .
سوال خیلی‌ مشگل هست به نظرم و باید صبر کرد خیلی‌ تخصصی‌ و حرفه ای هست عزیز.
:D :D :roll:

Masoud.ebi
20-08-2005, 20:59
یعنی چی خیلی تخصصیه

متوجه منظورتون نمیشم میشه واضحتر توضیح بدین

Nesta
20-08-2005, 21:29
سلام مسعود جان یعنی‌ سوال شما جوابش رو خیلی‌ راحت نمی‌شه داد و تخصصی‌ و سخت هستش .یعنی‌ همه این کار رو انجام نمیدهند که از پارادوکس به sql برن و بد شبکه کنند .

bithiah
26-08-2005, 10:22
ببخشين يه مشكل حين نصب SQL server:
موقع تنظيم Service Acounts هر چي نام كاربر و كلمه عبور و اسم كامپيوترم رو مي دم خطا مي گيذه كه The logon account cannot be validated for the SQL server service. Verify that the usernaame and password entered are correct. The logon attempt failed.
تو رو خدا كمك كنين. ديگه بريدم. :?

Nesta
26-08-2005, 22:39
سلام بیتا جان
1- sql server 2000 هست یا نه ؟
2- شما با پیشفرض نصب کن localhost رو بزن امتحان کن .شاید ثبت نشده باشه .
کلا دوباره نصب میکنی‌ اینطوری می‌شه .؟ آیا کلا پاک میکنی‌ ؟ یک درایو دیگه نصب کن ببین چی‌ می‌شه ؟
مشگل از ویندوز نیست ؟

Masoud.ebi
26-08-2005, 22:57
بابا نستا جان حالا یه کاریش بکن دیگه
حتما یه راهی هست براش توی عالم برنامه نویسی هر کاری ممکنه

Nesta
27-08-2005, 00:17
سلام مسعود جان مشگل شما اگه همون شبکه هست که می‌خواهید انتقال بدین رو سرور .من هنوز والا ندیدم کسی‌ از پارادوکس این کار رو کرده باشه همه خودشون با اس کیو ال این کار رو انجام میدان من حالا بهت میگم چی‌ کار کنی‌ .... :roll: :)

bithiah
27-08-2005, 07:30
نستا جان عزيز
ممنونن از توجهت. بالاخره يكي پيدا شد به اين انجمن سر بزنه.
خوشبختانه مشكلم بعد از كلي دردسر حل شد.
ممنون

Nesta
27-08-2005, 16:05
نستا جان عزيز
ممنونن از توجهت. بالاخره يكي پيدا شد به اين انجمن سر بزنه.
خوشبختانه مشكلم بعد از كلي دردسر حل شد.
ممنون
سلام بیتا جان من اینجا اصولا بد از رفتن امیر دست تنها هستم ..و من هرگز هم نباید در باره این انجمن سوال کنم که چی‌ می‌شه ..از شما هم شرمنده که دیر جواب میدم.
ولی‌ من سعی‌ می‌کنم که سریع تر جواب بدم .
:D

Adeli
30-08-2005, 07:37
سلام

Nesta
30-08-2005, 18:42
سلام
سلام دوست عزیز .
لطف کنید که قوانین این انجمن رو رعایت کنید ،
ورود شما هم تبریک میگیم بهتون .
ولی‌ شما برای پست دادن باید موضوع یا پاسخی‌ ارائه کنید .
سلام ؟؟؟
لطف کنید بیشتر توجه کنید.
8)

Sadjad Sharifian
04-09-2005, 14:21
سلام!! آقا دستم به دامنتون!!! من امروز Sql Server 2000 Enterprise Edition نصب کردم!! بعد هر کاری میکنم نمیتونم Connect کنم!! به هر دری که زدم نشد! هی میگه یا SQL Server وجود نداره یا اینکه دسترسی بهش ممنوعه!! در ضمن میخوام با ADO کار کنم و سیستم عاملم هم SP1 هستش!! مرسی.
یا علی.
پ.ن : آیا باید در مورد خاصی در تنظیمات ویندوز تغییر خاصی بدم؟! یا اینکه چیکار باید بکنم؟! :cry:

Nesta
05-09-2005, 02:23
سلام دوست عزیز شما microsoft frame work
NET_FreamWorks_2.0
نصب کردین ؟ بد شما باید کامل نصب کنید تا مشگلی‌ نه داشته باشید .

Sadjad Sharifian
05-09-2005, 12:15
سلام سعید جان....آقا من Frame Work 1.1 رو نصب کردم!! شما مطمئنید که باید FrameWork 2 رو نصب کرد؟! آخه من خواستم SQL Server 2005 رو نصب کنم اول گفت که باید 2 رو بریزم ولی برای 2000 از 1.1 ایرادی نگرفت!!
من اولش SQL Server 2000 Enterprise Edition رو نصب کرده بودم که باهاش اون مشکلات رو داشتم!! بعدش از تو خود سایتش [ برای مشاهده لینک ، لطفا با نام کاربری خود وارد شوید یا ثبت نام کنید ] دیدم که این نسخش فقط مال ویندوزهای NT و ایناس...که خوب من دارم از XP SP1 استفاده میکنم....بعد نوشته بود که Personal Edtion مناسبه!! منم اونیکی رو UnInstall کردم و Personal رو Install کردم....ولی بازم همه ی مشکلات قبلی هنوز سر جاش بود!! یعنی اصلا از هیچ جا نمیشه Connect کرد به SQL!! نه از تو خود Enterprise Manager خودش و نه از داخل Visual Studio!! چیکار باید بکنم که نکردم؟! :cry:
آقا سعید بازم دمت گرم که جواب دادی..
یا علی.

Nesta
05-09-2005, 18:31
سلام دوست عزیز برای 2000 هم اگه 2 رو نصب کنی‌ باز بهتر هست ولی‌ مشگلی‌ نیست .
در ضمن ویندوز 2000 و ان تی‌ هم بهتر جواب میده sql server ولی‌ به نظرم اگه شما نسخه 2000 فول اگه دارید یا کامل آنرا از اول نصب کنید .مشگلی‌ نیست و localhost هم راحت میتونین به عنوان سرور خود انتخاب کنید یعنی‌ پایگاه خودتون .آخه اینا زیاد مشگل نیست .بیشتر مربوط به نصب یا نسخه اصل بودن و ویندوز هست همین.متشکر.

Sadjad Sharifian
06-09-2005, 00:09
سلام دوست عزیز برای 2000 هم اگه 2 رو نصب کنی‌ باز بهتر هست ولی‌ مشگلی‌ نیست .
در ضمن ویندوز 2000 و ان تی‌ هم بهتر جواب میده sql server ولی‌ به نظرم اگه شما نسخه 2000 فول اگه دارید یا کامل آنرا از اول نصب کنید .مشگلی‌ نیست و localhost هم راحت میتونین به عنوان سرور خود انتخاب کنید یعنی‌ پایگاه خودتون .آخه اینا زیاد مشگل نیست .بیشتر مربوط به نصب یا نسخه اصل بودن و ویندوز هست همین.متشکر.

سلام...ممنونم!! هنوز که درست نشده!! من خودم تقریبا حدس میزنم که مشکل رو Personal FireWall داره بوجود میاره!! یعنی فایروال دسترسی به یه سری پورتهای مورد نیاز رو بسته احتمالا!!! البته احتمالا!! این حرف رو با استناد به این صفحه دارم میزنم : [ برای مشاهده لینک ، لطفا با نام کاربری خود وارد شوید یا ثبت نام کنید ] که البته این در مورد sp2 هست که خودش FireWall داره!! ولی خوب من دارم از sp1 + Norton Personal FireWall استفاده میکنم!! خیلی به دردسر خوردم!!نمیدونم چه باید کرد!! :cry:
بازم کلی مرسی از اینکه جواب دادی سعید جان..
یا علی.

Nesta
06-09-2005, 00:35
سلام دوست من حرف شما دقیقا درست هست و این فایر وال بعضی‌ اوقات یک کار هائی‌ می‌کنه که آدم اصلا نمیفهمه که کار اون هست ولی‌ بد که پیگیری میکنی‌ میبینی‌ که بله کاره خودش هست .از لطف شما هم سپاسگزارم ،فقط وظیفه هست . :wink:

شهراد
25-09-2005, 08:05
سلام
چطوری میشه فهمید که SQL Server یک کامپیوتر چه Service Pack ی روش نصب است و چه ورژنی دارد .
با تشکر از تمام دوستان و برنامه نویسان حرفه ای.

Nesta
25-09-2005, 15:35
سلام دوست عزیز شما در قسمت enterprice manager وارد که میشی‌ در قسمت about می‌نویسه و اگه در اینترنت باشید update رو بزنید که خودش میره واسه upgrade sp. های جدید

شهراد
26-09-2005, 09:18
ممنون دوست عزیز

Nesta
26-09-2005, 21:05
سلام خواهش می‌کنم آقای شهراد .
سپاسگزارم

Masoud.ebi
01-10-2005, 14:16
Nesta نوشته : تاریخ ارسال 26/8/2005
سلام مسعود جان مشگل شما اگه همون شبکه هست که می‌خواهید انتقال بدین رو سرور .من هنوز والا ندیدم کسی‌ از پارادوکس این کار رو کرده باشه همه خودشون با اس کیو ال این کار رو انجام میدان من حالا بهت میگم چی‌ کار کنی


نستا جان بالاخره من چیکار کنم
یه راهی جلو پام بذار
یعنی هیچ راهی نداره برا ترانسفرش

Nesta
01-10-2005, 15:26
سلام مسعود جان آقا من شرمنده هستم .آخه کسی‌ نکرده همچین کاری رو .میدونی‌ چرا چون که واسه شبکه sql server mysql اینا اسمش روش هست و کسی‌ دیگه نمیره مثلا با اکسس درست کنه بدن انتقال بده رو اس کیو ال .شما باید از یکی‌ که خیلی‌ وارد هست در زمینه بانک اطلاعاتی‌ بپرسی‌ .یا این که بانک رو از اول رو sql server پیاده سازی کنی‌ .

Masoud.ebi
01-10-2005, 15:56
نستا جان
من آشنایی کمی با اس کیو ال دارم
برا طراحی مجدد این بانک ها بر روی اس کیو ال یا اوراکل میتونی کمکم کنی ؟

اگه بتونی ممنون میشم

Nesta
01-10-2005, 23:11
سلام تا انجا که وقت کنم باشه من Sql server کار کردم oracle که افراد کمی بلد هستند

Masoud.ebi
12-10-2005, 09:09
خوب نستا جان
من سه تا بانک اطلاعاتی پارادوکس دارم
که بزرگترین اون 122 تا فیلد داره از انواع مختلف
برای ایجاد بانک های مذکور و نحوه اتصال کامپوننت ها به دیتابیس همچنین نحوه ایجاد حساب های کاربری برای اتصال به بانک و نحوه مسیردهی به اکونت ها و ایجاد ایندکس های اولیه و ثانویه برای فیلتر نمودن جداول رو اگه ممکنه لطف کنید و توضیح بدین
اگه اطلاعات بیشتری از برنامه میخواین بگین تا بذارم

ENTEZAR
13-10-2005, 11:01
سلام
ما يه برنامه اي داريم که ديتابيس آن SQL Server است
حالا روي تمام کلاينتها گاهي وقتها خطاي Connection Failed ميده و خلاصه کلي درد سر درست کرده برام
سوالم اينه که کلا SQL Server چقدر پهناي باند نياز داره و چگونه مي تونم با نرم افزار Performance بفهمم مشکل از SQL Server است يا نرم افزار يا شبکه

ممنون

Nesta
14-10-2005, 04:18
سلام مسعود جان این که 7 تا سوال در یکی‌ شد .شوخی‌ می‌کنم .
حالا نحوه اتصال که دیگه یک ثبت پایگاه جدید در سرور و همچنین معرفی‌ client ها و ارتباط بانک اطلاعاتی‌ به پایگاه داده شما هست .برات جدول هم که در قسمت sql server Enterprice Manager میتونین جدول رو ایجاد کنین و به بانک و پایگاه داده خودتون و همچنین نام صاحب پایگاه ایجاد کنید .
در مورد ایندکس هم باید مفصل بحث بشه .فعلا شما دونه دونه برو جلو .حالا من نمیدونم که شما تا چه هادی کار کردین و بلد هستین .که چطوری بگم .

Masoud.ebi
14-10-2005, 12:11
نستا جان سلام
شما تصور کن من مبتدی هستم حالا اگه زحمتتت نیست قدم بقدم ما رو راهنمایی کن

ممنون میشم

FATIMA
17-02-2006, 11:32
سلام
فرق MySQL با SQL Server چيه؟
اصلا با هم فرق دارن يا نه؟

folad
07-05-2006, 15:21
چگونه ميتوانم تمام ركوردهاي تمامي جداول موجود در يك بانك اطلاعاتي را كه همگي داراي فيلدهاي يكسان هستند در يك جدول در بانك اطلاعاتي ديگر جمع آوري كنم؟

MHSM
23-07-2006, 00:51
سلام. :biggrin:
همون طور که میدونید SQL Server بهترين بانك هستش. ولي برنامه اي كه مي نويسم براي اجراي اون و بانك اون حتما بايد SQL نصب بشه. من شنيدم كه ميشه كاري كرد كه بدون نياز به نصب SQL ميشه با بانك اطلاعاتي اون كار كرد. :blink:
سوال من اينه كه چطوري برنامه اي كه بانكش SQL هستش رو بدون نصب برنامه SQL روي يك كامپيوتر ديگه اجرا و به بانك اطلاعاتيش كار كنيم :blink: .
ممنون از همه. :)

raahaa
26-07-2006, 14:44
ببخشيد ميشه پروزه دفترچه تلفن در اسكيو ال رو برام بنو يسيد

مهدی دائی پور
09-08-2006, 01:35
[سلام
من تازه تو اين سايت ثبت نام كردم لطفا نحوه اتصال يك بانك sql server به دلفي و جستجو در يك فيلد رو برام بنويسين
با تشكرات فراوان

mahdi_61
21-08-2006, 13:52
سلام

من cd اين نرم افزار را گرفتم ولي نمي تونم نصب كنم مي خواستم بدونم روش خاصي داره يا مثل بقيه نرم افزارهاست؟؟؟؟

متشكر

boy of outworld
29-08-2006, 04:06
سلام اقا يك مشكلي دارم هركي ميتونه منو راهنمايي كنه خيلي ممنون مي شم مي خواستم بدونم اگه يه صفحه وب داشته باشيم-- كه نام نام خانوادگي وآدرس رو از كاربر بگيره بعد اونارو پاس بده به يه صفحه نا معلوم بعد از چك كردن اين سه متغير شماره تلفن طرف رو بده -- ميتونيم كاري بكنيم كه كل بانك يه جا ديده بشه يا نه) به جاي اينكه اسم يا نام خانوادگي و ... رو بديم بتونيم كل اطلاعات بانكش رو ببينيم؟
هركي تونس كمك كنه يا همينجا نظرش رو بده كه همه استفاده كنن يا توي ياهو برام اف بزاره boy_of_outworld_666@yahoo.com
مرسي!!!

hghb
18-01-2007, 12:42
در زمان نصب SQL Server Enterprise پیغام خطای زیر نمایش داده میشود
MicroSoft SQL Server 2000 Enterprise Edition server component is not supported on this operation systrm. Only Client components will be avalible for installation
برای برطرف شدن این خطا چه باید بکنم.
ضمناً سیستم عامل من ویندوز اکس پی سرویس پک 2 است و کامپیوتر من کارت شبکه ندارد.

soaleman
12-07-2010, 18:40
با سلام خدمت دوستان
مدتي يك سوال رو تو چند تاپيك و فروم مطرح كردم اما اصلاً در اين تاپيك ها هيچ فعاليتي نيست
خواهش مي كنم اگه كسي ميتونه جواب منو بده

من تو SQL Server يك package درست كردم كه اطلاعات يك Sheet تو Excel رو تو يك Table از بانكم وارد ميكنه

حالا ميخوام اين package تحت دستورات StoreProcedure فراخواني كنم و اجراش كنم

اميد وارم منظورم رو رسونده باشم
با سپاس

king-hitler2
07-08-2010, 00:22
سلام کسی اموزش تصویری رو نداره
بد لازم دارم

elyas_gh
31-01-2015, 15:02
سلام به دوستان
چطور میتونم اطلاعات موجود در یک sql server را (جداول) را به طور خودکار به کامپیوتر دیگر که از طریق شبکه باهم در ارتباط هستند ارسال کنم.(مثلا بصورت یک فایل اکسل)
بدین صورت که هر یک ساعت بصورت اتوماتیک این عمل انجام شود.
این مقادیر را می خواهم در نرم افزار WINCC نمایش دهم.
با تشکر

H.E.R.O.E.S
01-02-2015, 01:51
سلام به دوستان
چطور میتونم اطلاعات موجود در یک sql server را (جداول) را به طور خودکار به کامپیوتر دیگر که از طریق شبکه باهم در ارتباط هستند ارسال کنم.(مثلا بصورت یک فایل اکسل)
بدین صورت که هر یک ساعت بصورت اتوماتیک این عمل انجام شود.
این مقادیر را می خواهم در نرم افزار WINCC نمایش دهم.
با تشکر

منظوذتون و دقیق متوجه نشدم اگر دقیق تر توضیح بدید شاید بهتر بتونم کمکنون کتن

elyas_gh
01-02-2015, 08:25
با سلام و تشکر
بر روی یک سیستم نرم افزار گزارش گیری و آماری از یک پروسه نصب می باشد که در آن از SQL Server استفاده شده است.(سیستم اول)
در سیستم دیگر نرم افزار مانیتورینگ زیمنس WINCC نصب می باشد که از آن جهت راهبری و کنترل پروسه استفاده می شود و آن نیز دارای SQL SERVER2015 می باشد.(سیستم دوم)
من می خواهم که اطلاعات آماری که در سیستم اول می باشد را به سیستم دوم انتقال دهم. چون اطلاعات آماری ارسالی از واحد کنترل کیفی می باشد و بوسیله جداول کاغذی به اپراتور کنترل ارسال می شود و من در نظر دارم این اطلاعات را از سیستم اول از طریق شبکه دریافت کرده و به سیستم دوم ارسال و نهایتا بر روی سیستم مانیتورینگ بصورت همان جداول ، نمایش دهم.
هر دو سیستم مجزا از هم می باشند و فقط از طریق شبکه به هم متصل هستند.
آیا این امکان وجود دارد که بصورت خودکار در یک بازه زمانی این اطلاعات را از سیستم اول به سیستم دوم ارسال کنم.البته اگر در سیستم دوم در فایل اکسل وارد شوند هم مشکلی ندارم.
و یا اینکه این جداول بصورت اتوماتیک از SQL سیستم اول SQL سیستم دوم منتقل شوند.
با تشکر

mar_jan
10-12-2015, 11:45
سلام قراره یه پرس و جو ( Query ) بنویسیم ک بهمون بگه دانشجو چند ترمه فارغ التحصیل شده خودم کد ریر رو نوشتم اما مشکل داره تعداد درسا رو نشون میدهکسی بلده؟؟؟؟

برای مشاهده محتوا ، لطفا وارد شوید یا ثبت نام کنید