четверг, 30 августа 2012 г.

Ubuntu: команда "apt-get update" выдает ошибку 404

 
     Если при выполнении команды apt-get update / apt-get upgrade получаем ошибку "404 Not Found", то проблема вызвана следующей причиной:

Ваш релиз Ubuntu более не поддерживается:

    Проверить поддерживается ли Ваш релиз и/или когда была/будет прекращена поддержка можно https://wiki.ubuntu.com/Releases (раздел End of Life).
    Проверить версию релиза можно командой:    
lsb_release -a

    Если релиз релиз  не поддерживается, то надо произвести его upgrade. Для этого переходим по https://help.ubuntu.com/community/UpgradeNotes . Находим наш релиз и смотрим раздел "See more information for upgrade".
    Для примера обновим Ubuntu 8.10.
    Согласно примеру из статьи на надо в репозитарий внести следующие источники:
 
## EOL upgrade sources.list
# Required
deb http://old-releases.ubuntu.com/ubuntu/ intrepid main restricted universe multiverse
deb http://old-releases.ubuntu.com/ubuntu/ intrepid-updates main restricted universe multiverse
deb http://old-releases.ubuntu.com/ubuntu/ intrepid-security main restricted universe multiverse
# Optional
#deb http://old-releases.ubuntu.com/ubuntu/ intrepid-backports main restricted universe multiverse
#deb http://old-releases.ubuntu.com/ubuntu/ intrepid-proposed main restricted universe multiverse

    Важно, все остальные, имеющие источники надо закомментировать.
    Для внесения изменений в список репозитариев вводим команду в терминале:
sudo mcedit /etc/apt/sources.list
    1 И правим данный файл,согласно рекомендации выше и сохраняем его.
    2. Далее вводим команду в терминале:
sudo aptitude update && sudo aptitude safe-upgrade
    3. Производим обновление релиза:
sudo do-release-upgrade
    4. Перезагружаем компьютер и проверяем версию релиза командой:
lsb_release -a
    Если в результате мы получили релиз который также не поддерживается заново производим эти же действия, только уже для другого релиза
Оригинал статьи взят http://h3x.no/2010/11/08/ubuntu-apt-get-update-gives-404-not-found-error

среда, 22 августа 2012 г.

POSTRESQL (Npgsql) и C#

Взято из статьи: http://npgsql.projects.postgresql.org/docs/manual/UserManual.html
Перевел, что посчитал нужным.
Качаем драйвер Npgsql для MS.Net от отсюда.
Добавляем в проект ссылки на данный драйвер и namespace:
using Npgsql;

Установка соединения с СУДБ
Сервер:  127.0.0.1, Порт:  5432 (по умолчанию), Пользователь: postgres (по умолчанию), Пароль: 12345678, База данных: testd
using System;
using System.Data;
using Npgsql;
public class NpgsqlUserManual
{
    public static void Main(String[] args)
    {
         NpgsqlConnection conn = new NpgsqlConnection("Server=127.0.0.1;Port=5432;User Id=postgres;Password=12345678;Database=testd;");
        conn.Open();
        conn.Close();
     }
}

Добавление записей в таблицу
ExecuteNonQuery() - идеально подходит для добавление или обновления записей, поскольку, возвращает целое число - добавленных/измененных "рядов".
using System;
using System.Data;
using Npgsql;
public static class NpgsqlUserManual
{
    public static void Main(String[] args)
    {
        NpgsqlConnection conn = new NpgsqlConnection("Server=127.0.0.1;Port=5432;User Id=postgres;Password=12345678;Database=testd;");
        conn.Open();
        NpgsqlCommand command = new NpgsqlCommand("insert into table1 values(1, 1)", conn);
        int rowsaffected;
        try
        {
            rowsaffected = command.ExecuteNonQuery();
            Console.WriteLine("It was added {0} lines in table table1", rowsaffected);
        }
        finally
        {
            conn.Close();
        }
    }
}

ExecuteScalar() - получение результата содержащее единственную запись.
NpgsqlCommand command = new NpgsqlCommand("select version()", conn);
String serverversion;
try
{
    serverversion = (String)command.ExecuteScalar();
    Console.WriteLine("PostgreSQL server version: {0}", serverversion);
}
finally
{
    conn.Close();
 }

Получение результата. метод ExecuteReader() и NpgsqlDataReader.
NpgsqlCommand command = new NpgsqlCommand("select * from tablea", conn);
try
{
    NpgsqlDataReader dr = command.ExecuteReader();
    while(dr.Read())
    {
        for (i = 0; i < dr.FieldCount; i++)
        {
            Console.Write("{0} \t", dr[i]);
        }
        Console.WriteLine();
    }
}
finally
{
   conn.Close();
}

Использование параметров в запросах.
Параметры позволяют динамически добавлять значения в текст запроса в режиме run-time. Обозначение параметра в тексте запроса производится с использованием префикса ":"
// Заявление параметров в строке запроса
using(NpgsqlCommand command = new NpgsqlCommand("select * from tablea where column1 = :value1", conn))
{
    //Добавим параметр в коллекцию специального типа
    command.Parameters.Add(new NpgsqlParameter("value1", NpgsqlDbType.Integer));
    //Добавим значение в параметр в команда
    command.Parameters[0].Value = 4;
    using(NpgsqlDataReader dr = command.ExecuteReader())
    {
        while(dr.Read())
        {
            for (i = 0; i < dr.FieldCount; i++)
            {
                Console.Write("{0} \t", dr[i]);
            }
         Console.WriteLine();
        }
    }
}