سلام؛ متاسفانه صفحه بندی مشکل داره ، اگه itemsPerPage را تغییر بدیم متاسفانه تعداد صفحهها کم و زیاد نمیشه . روی مثال خودتون 1500 رکورد اطلاعات هست اگه itemsPerPage بشه 10 تعداد صفحهها 150 هست و اگه بشه 5 هم 150 هست و تا رکورد 750 نمایش میده.
نظرات مطالب
ASP.NET MVC #11
من از ویندوز 10 استفاده میکنم. زمانی که تاریخ ویندوز بر روی میلادی تنظیم شده رشته تاریخ فارسی به معادل میلادی بدون مشکل تبدیل میشود. اما وقتی تاریخ ویندوز در حالت شمسی هست بعد از عملیات تعریف شده در بایندر باز هم تاریخ بصورت شمسی هست .
بعد از عملیات
اگر ممکنه راهنمائی بفرمائید.
نظرات مطالب
استفاده از Froala WYSIWYG Editor در ASP.NET
سلام
ممنون برای این مطلب
فکر کنم این ادیتور با کروم یک مشکل داره:
برای مثال کلمه «تست» رو در اون تایپ کنید، سپس بعد از «س» یک حرف جدید مثل «ن» وارد کنید: نتیجه باید بشود «تسنت» اما میشود «تسنت».
البته من در کروم 34 تست کردم. با IE 10 و Firefox 28 مشکلی نداشت.
The 18.6 release is the second major release of SSMS in 2020 and packs several high impact changes , including a fix for crashes in database diagram s. Key fixes include:
- Save to XEL file error fix.
- B acpac file import error fix.
- Database diagrams crash fix.
- Addressed sources o f three common application hangs.
اشتراکها
16.Visual Studio 2017 15.9 منتشر شد
Issues Fixed in 15.9.16
- Assembly does not match code for function
- System.InvalidProgramException: Common Language Runtime detected an invalid program. when instrumenting x64 projects
- Cross-EH mode inlining of noexcept code produces unexpected behavior
- Corrected issue with HTML Help Workshop failing to repair.
Security Advisory Notices
پس از مدتی که از شروع به کار یک سیستم میگذرد، همانطور که تعریف ایندکسهای مفید سرعت جستجوها را بالا میبرد، ایجاد fragmentation در آنها نیز تاثیر منفی در کارآیی خواهد داشت. به همین منظور نیاز است هر از چندگاهی بررسی شود میزان fragmentation ایندکسها چقدر است. اگر این میزان بیش از 30 درصد بود توصیه شده است که از دستور DBCC INDEXDEFRAG استفاده شود یا بازسازی مجدد ( rebuild ) ایندکسها صورت گیرد.
یکی دیگر از امکانات dmv های اس کیوال سرورهای 2005 به بعد، ارائه آمار میزان fragmentation ایندکسها است که کوئری آن به صورت زیر میتواند باشد:
USE dbName;
SELECT OBJECT_NAME(DMV.object_id) AS TABLE_NAME,
SI.NAME AS INDEX_NAME,
avg_fragmentation_in_percent AS FRAGMENT_PERCENT,
DMV.record_count
FROM sys.dm_db_index_physical_stats(DB_ID(), NULL, NULL, NULL, 'SAMPLED') AS
DMV
LEFT OUTER JOIN SYS.INDEXES AS SI
ON DMV.OBJECT_ID = SI.OBJECT_ID
AND DMV.INDEX_ID = SI.INDEX_ID
WHERE avg_fragmentation_in_percent > 10
AND index_type_desc IN ('CLUSTERED INDEX', 'NONCLUSTERED INDEX')
AND DMV.record_count >= 2000
ORDER BY
TABLE_NAME DESC
باید در نظر داشت که اجرای این کوئری بر روی یک دیتابیس حجیم زمانبر بوده و احتمالا عملکرد سیستم را تحت تاثیر قرار میدهد. بنابراین استفاده از آن در خارج از ساعات کاری باید مد نظر باشد. بازسازی ایندکسها نیز به همین صورت است.
برای بازسازی تمامی ایندکسهای یک دیتابیس مفروض میتوان از کوئری زیر استفاده کرد:
DECLARE @TableName VARCHAR(255)
DECLARE @sql NVARCHAR(500)
DECLARE @fillfactor INT
SET @fillfactor = 80
DECLARE TableCursor CURSOR
FOR
SELECT OBJECT_SCHEMA_NAME([object_id]) + '.' + NAME AS TableName
FROM sys.tables
OPEN TableCursor
FETCH NEXT FROM TableCursor INTO @TableName
WHILE @@FETCH_STATUS = 0
BEGIN
SET @sql = 'ALTER INDEX ALL ON ' + @TableName +
' REBUILD WITH (FILLFACTOR = ' + CONVERT(VARCHAR(3), @fillfactor) + ')'
EXEC (@sql)
FETCH NEXT FROM TableCursor INTO @TableName
END
CLOSE TableCursor
DEALLOCATE TableCursor
یکی دیگر از کاربردهای anonymous types ، امکان استفاده از قابلیتهای LINQ برای جستجوی فایلها و پوشهها است.
مثال:
using System;
using System.Linq;
using System.IO;
namespace LINQtoDir
{
class Program
{
static void Main(string[] args)
{
var query = from f in new DirectoryInfo(@"C:\Documents and Settings\vahid\My Documents\My Pictures")
.GetFiles("*.*", SearchOption.AllDirectories)
where f.Extension.ToLower() == ".png" || f.Extension.ToLower() == ".jpg"
orderby f.LastAccessTime
select new
{
DateLastModified = f.LastWriteTime,
Extension = f.Extension,
Size = f.Length,
FileName = f.Name
};
foreach (var file in query)
Console.WriteLine(file.FileName);
Console.WriteLine("Press a key...");
Console.ReadKey();
}
}
}
در این مثال توسط کوئری نوشته شده، تمامی تصاویر jpg و یا png موجود در پوشه my pictures یافت شده و سپس بر اساس LastAccessTime مرتب میشوند. در آخر با استفاده از anonymous types ، یک شیء IEnumerable از خواص مورد نظر فایلهای یافت شده، بازگشت داده میشود. اکنون هر استفادهی دلخواهی را میتوان از این شیء انجام داد.
In short, domain events help you to express, explicitly, the domain rules, based in the ubiquitous language provided by the domain experts. Domain events also enable a better separation of concerns among classes within the same domain.
It's important to ensure that, just like a database transaction, either all the operations related to a domain event finish successfully or none of them do.
Domain events are similar to messaging-style events, with one important difference. With real messaging, message queuing, message brokers, or a service bus using AMQP, a message is always sent asynchronously and communicated across processes and machines. This is useful for integrating multiple Bounded Contexts, microservices, or even different applications. However, with domain events, you want to raise an event from the domain operation you are currently running, but you want any side effects to occur within the same domain.
The domain events and their side effects (the actions triggered afterwards that are managed by event handlers) should occur almost immediately, usually in-process, and within the same domain. Thus, domain events could be synchronous or asynchronous. Integration events, however, should always be asynchronous.
نظرات مطالب
یافتن تداخلات Collations در SQL Server
تهیه اسکریپت تغییر Collation تمامی فیلدهای ناهمگون در دیتابیس جاری :
DECLARE @defaultCollation NVARCHAR(1000) SET @defaultCollation = CAST( DATABASEPROPERTYEX(DB_NAME(), 'Collation') AS NVARCHAR(1000) ) select 'ALTER TABLE ' + QUOTENAME(C.TABLE_SCHEMA) +'.'+ QUOTENAME(C.Table_Name) +' ALTER COLUMN ' +' [' +Column_Name+'] ' + DATA_TYPE+'('+cast(character_maximum_length as varchar(10))+')' +' COLLATE Persian_100_CI_AS ' +(case IS_NULLABLE when 'YES' then 'NULL' else 'NOT NULL' end )+';' FROM Information_Schema.Columns C INNER JOIN Information_Schema.Tables T ON C.Table_Name = T.Table_Name WHERE T.Table_Type = 'Base Table' AND RTRIM(LTRIM(Collation_Name)) <> RTRIM(LTRIM(@defaultCollation)) --AND DATA_TYPE='nvarchar' AND character_maximum_length>0 ORDER BY C.Table_Name, C.Column_Name