четверг, 31 мая 2012 г.

Batch updates в Grails с использованием HQL

ScrollableResults scroll = getSession()
.createQuery("SELECT DISTINCT t FROM ${tableName} as t LEFT JOIN t.tags as tags WHERE tags.id in (:tags)")
.setParameterList("tags", [oldTag1.id, oldTag2.id])
.scroll(ScrollMode.FORWARD_ONLY) int count = 0;

 while (scroll.next()) {
  def exp = scroll.get(0)
  exp.tags.remove(oldTag1)
  exp.tags.remove(oldTag2)
  exp.tags.add(newTag)
  exp.save()
  if (++count % 20 == 0)
  {
    session.flush();
    session.clear(); }
  }

Для работы данного когда надо получить CurrentSession из SessionFactory.
Данный код выполняет HQL запрос и когда число строк обработанных в результате запроса без остатка делится на 20  то сессия хибернейта выполняет flush и clean, что позволяет не загружать память при больших запросах.

четверг, 26 мая 2011 г.

Обновление Fedora Core с 14 до 15 версии

Для обновления своей "Федоры" вам необходимо скачать пакет с репозитария

Fedora Core

fedora-release-15-1.noarch.rpm


Для пользователей Russian Fedora

rfremix-release-15-1.R.noarch.rpm


После скачивания, установите пакет:

Fedora Core

rpm -i fedora-release-15-1.noarch.rpm


Для пользователей Russiaon Fedora

rpm -i rfremix-release-15-1.R.noarch.rpm


После установки пакета вам необходимо отчистить репозитариии yum:

yum clean all



Теперь заветная команда:
yum update


и готовимся получать новые пакеты....


P.S.: Не всегда обновление проходит удачно.. ;) Удачи...

среда, 26 января 2011 г.

Гарантирует ли ORDER BY порядок вставки в таблицу?

Вопрос: Гарантирует ли ORDER BY порядок вставки в таблицу?
Ответ: нет не гарантирует

НО есть маленькая особенность, если таблица содержит поле IDENTITY(!!!)

Если перенос данных делать через

SELECT Col1, Col2, ID=IDENTITY (int, 1, 1)
INTO NewTable
FROM OldTable
Order By Col1

То в разных ситуация может получиться разная картина, и даже так:
Col1 Col2 ID
------- -------- --------
1 A 4
2 Z 2
7 G 5
11 F 3
17 I 1


Если вставку делать в таблицу, которая создана заранее и содержит поле IDENTITY, то вставка:

INSERT INTO NewTable (Col1, Col2) SELECT Col1, Col2 FROM OldTable ORDER BY Col1

ГАРАНТИРУЕТ, что поле идентити будет следовать согласно полю по которому идёт сортировка
ID (identity) Col1 Col2
------------- ------ ------
1 1 S
2 2 z
3 7 G
4 11 F
5 17 I


Но это не гарантирует, опять же, физический порядок вставки. Вся особенность в том, что во втором случае значения поля идентити генерятся ДО самой вставки на базе условия ORDER BY.

ЗЫ: Печально, что в BOL это не описано, точнее убого описано и споров в форумах на эту тему нашёл больше, чем рассчитывал.

Ссылки по теме:
http://blogs.msdn.com/b/sqltips/archive/2005/07/20/441053.aspx
http://support.microsoft.com/kb/273586/en-us/
Спасибо Алексею Князеву за предоставленую информацию.

пятница, 21 января 2011 г.

Удаление дублей в таблице без первичных ключей

Задача:
Необходимо одним запросом удалить дублирующийся строки в таблице, записи в которой не имеют уникальных ключей

Решение:
WITH cte
AS
(
SELECT ROW_NUMBER() OVER (PARTITION BY id ORDER BY name) id, * FROM table
)
DELETE FROM cte WHERE id > 1

P.S.: Данное решение возможно только на MS SQL серверах выше 2000 версии

понедельник, 29 ноября 2010 г.

Лекции по Системам реального времени

Отсканированные лекции по Системам реального времени, готовимся к зачету =)
P.S.: Спасибо Игорю Мартемьянову

Леции

четверг, 25 ноября 2010 г.

Методичка и Задачник по Организации и Планированию производства

Отсканированный вариант Методички и Задачника по предмету "Организация и планирование производства"
Задачник
Методичка

пятница, 15 октября 2010 г.

Получение пользователей из AD на C#

using System;
using System.DirectoryServices;
using System.Collections;
using System.Linq;
using System.IO;

class Program
{

static void Main(string[] args)
{
DirectoryEntry de = new DirectoryEntry("LDAP://"+serverName, userName, password);
DirectorySearcher deSearch = new DirectorySearcher();

deSearch.SearchRoot = de;
deSearch.Filter = "(&(objectClass=user))";
deSearch.SearchScope = SearchScope.Subtree;

SearchResultCollection results = deSearch.FindAll();

foreach (SearchResult result in results)
{
DirectoryEntry entity = result.GetDirectoryEntry();

if ((entity.SchemaEntry.Name == "user") && (entity.Name.IndexOf("CN=") != -1))
{
Console.Write(entity.Name.Substring(3) + "\n");
}
}
}
}