ارسال پارمتر به استیمول سافت توسط stored procedure - خطای incorect syntax near
با سلام به دوستان عزیز
یه مشکل برام در ارسال پارامتر به استیمول سافت اومده .
یه گزارش طراحی کردم که با ارسال نام مسیول پیگیری و همچنین از تاریخ تا تاریخ با استفاده از stored procedure به استیمول سافت . موقعی که نام مسیول پیگیری بدون فاصله باشه گزارشگیری رو میاره ولی وقتی نام مسیول پیگیری با فاصله باشه مثلا نام "وظیفه شناس " رو وارد کردنی خطا میده البته Trim هم گذاشتم ولی نمی دونم مشکل از کجاس . در ضمن وقتی جهت تست پارامتر رو دستی به استیمول سافت می دم اصلا خطا نمیاره.
کد stored procedure
Alter procedure Sp_MasoulPaigiri
@FromDate datetime,
@ToDate datetime,
@MasoulPaigiri nvarchar(max)
As
Begin
select
NameKarGoroh,
MasoulAjra,
MasoulPaigiri,
SharhTasmimat,
VaziatAnjam,
(Case When VaziatAnjam = 1 then 'انجام شد' When VaziatAnjam = 2 then 'در حال انجام' When VaziatAnjam = 3 then 'انجام نشده' When VaziatAnjam = 4 then 'کنسل شد' When VaziatAnjam = 5 then 'Hold' else '' end )as VaziatAnjamDesc,
(select [dbo].[sp_ConvertToSolarDate](DateSabt)) As ShamsiDateSabt,
(select [dbo].[sp_ConvertToSolarDate](MohlatAnjam)) As ShamsiMohlatAnjam
from Nezarat_Tbl
where LTRIM(RTRIM(MasoulPaigiri)) = LTRIM(RTRIM(@MasoulPaigiri))
and(DateSabt >= @FromDate and DateSabt <= @ToDate)
End
استیمول سافت

خطایی که میده ....

پاسخ هوش مصنوعی
به نظر می رسد که خطا به دلیل وجود فاصله های نادرست یا مشکلات در نحوه ارسال پارامتر به Stored Procedure باشد. اگر وقتی نام مسیول پیگیری با فاصله باشد خطا می دهد، ممکن است نیاز باشد که پارامترهای ورودی را به دقت بررسی کنید.
شما می توانید از LTRIM و RTRIM برای حذف فاصله های اضافی در دو طرف رشته استفاده کنید، که در کد شما انجام شده است. ولی ممکن است در قسمتی که پارامتر را به استیمول سافت ارسال می کنید، مقادیر حاوی فاصله نامناسب باشند.
برای رفع ایراد، مطمین شوید که پارامتر ورودی به شکل صحیحی ارسال می شود و همچنین در استیمول سافت، قبل از ارسال پارامتر، از توابع LTRIM و RTRIM نیز استفاده کنید. در اینجا یک کد برای مثال ارایه می کنم که می توانید در قسمت ارسال پارامتر در استیمول سافت استفاده کنید:
DECLARE @TrimmedMasoulPaigiri NVARCHAR(MAX)
SET @TrimmedMasoulPaigiri = LTRIM(RTRIM(@MasoulPaigiri))
EXEC Sp_MasoulPaigiri @FromDate, @ToDate, @TrimmedMasoulPaigiri
اطمینان حاصل کنید که این تغییرات را در تمام جاهایی که پارامتر را در استفاده از استیمول سافت ارسال می کنید اعمال کنید تا از بروز خطاهای مشابه جلوگیری شود.
بنظرم خطای شما در بخش کوئری Sql هست. کوئری شما در بخش Where به شکل زیر هست.
where LTRIM(RTRIM(MasoulPaigiri)) = LTRIM(RTRIM(@MasoulPaigiri))
بهتره از عملگر = برای رشته استفاده نکنید. به صورت زیر تغییر بدید :
where MasoulPaigiri Like '%' + @MasoulPaigiri + '%'
دستور بالا برای رشته بهتر جواب میده.
- آموزش استفاده از پلاگین گردونه شانس در Asp.net core به همراه سورس
- نمایش متن به صورت فرمت شده در CkEditor
- آموزش استفاده از SignalR در Asp.net Core با مثال عملی
- ادغام چند گزارش استیمول سافت بصورت پی دی اف در یک فایل
- نحوه تغییر استایل کامپوننت select2 چگونه است ؟
- چگونه امنیت پروژه را در Asp.net Core افزایش دهیم ؟
- ارسال پارامتر در دستور window.open جی کویری
- ارسال پارامتر از طریق جاوااسکریپت با کلیک روی تگ a
- خطای 500 زمان اجرا شدن پروژه روی هاست
- کویری نویسی در استیمول سافت جهت فیلتر اطلاعات
- کار با CkEditor با قابلیت آپلود عکس
- خطا در ایجاد migration در Asp.net core
- تفاوت های Asp.net core و Asp.net mvc چیه؟
- دلیل اسپم شدن ایمیل های ارسالی از سرور
- نحوه لایه بندی پروژه Core و اضافه کردن به IIS
- ارسال ایمیل در Asp.net core
- آیا میشه در mvc core از کامپونت استفاده کرد
- آپلود فایل در Asp.net core چگونه است؟
- حذف کامل یک رکورد در جدول ریلیشن شده
- اشکال در آپلود فایل ویدیو در mvc core 2