На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
! ПРАВИЛА РАЗДЕЛА · FAQ раздела Delphi · Книги по Delphi
Пожалуйста, выделяйте текст программы тегом [сode=pas] ... [/сode]. Для этого используйте кнопку [code=pas] в форме ответа или комбобокс, если нужно вставить код на языке, отличном от Дельфи/Паскаля.
Следующие вопросы задаются очень часто, подробно разобраны в FAQ и, поэтому, будут безжалостно удаляться:
1. Преобразовать переменную типа String в тип PChar (PAnsiChar)
2. Как "свернуть" программу в трей.
3. Как "скрыться" от Ctrl + Alt + Del (заблокировать их и т.п.)
4. Как прочитать список файлов, поддиректорий в директории?
5. Как запустить программу/файл?
... (продолжение следует) ...

Вопросы, подробно описанные во встроенной справочной системе Delphi, не несут полезной тематической нагрузки, поэтому будут удаляться.
Запрещается создавать темы с просьбой выполнить какую-то работу за автора темы. Форум является средством общения и общего поиска решения. Вашу работу за Вас никто выполнять не будет.


Внимание
Попытки открытия обсуждений реализации вредоносного ПО, включая различные интерпретации спам-ботов, наказывается предупреждением на 30 дней.
Повторная попытка - 60 дней. Последующие попытки бан.
Мат в разделе - бан на три месяца...
Модераторы: jack128, D[u]fa, Shaggy, Rouse_
  
> MYSQL и BOOLEAN
    Есть у меня одна програмка, работает с базой данных Acсess. Дошёл до момента перевода этого софта на удалённую базу на сервере MySQL. Наткнулся на одну нерешимую для меня задачу, дабы софт полностью не переписывать, а именно на то, что в MySQL тип столбца почему-то становится tinyint(1) вместо boolean

    Может кто знает решение как адаптировать BOOLEAN в программе и TINYINT(1) в базе, чтобы много кода не менять?
    delphi xe5
    adoconection
    adotable
      Цитата dreyqq @
      TINYINT(1)

      Я как понимаю это Int8 в delphi. целое 1 байтное.
      типа того что-ли...
      ExpandedWrap disabled
        function BoolToInt8(b:boolean):int8;
        begin
          if b then result:=1 else result:=0;
        end;

      т.е. все передачи базы обрабатывай через функцию
        Решил проблему с помощью двух функций, и перехода в базе от BOOLEAN к INTEGER
        ExpandedWrap disabled
          function BtoI(b:boolean):integer;
          begin
            if b=true then result:=1 else result:=0;
          end;
           
          function ItoB(i:integer):boolean;
          begin
            if i=1 then result:=true else result:=false;
          end;

        В базе заменил на тип столбца INTEGER и в программе обработал всё через эти две функции
        0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
        0 пользователей:


        Рейтинг@Mail.ru
        [ Script execution time: 0,0186 ]   [ 16 queries used ]   [ Generated: 19.04.24, 21:32 GMT ]