ultimatepp/reference/SQL_PostgreSql/Postgres.cpp
2025-02-02 14:08:20 +01:00

90 lines
1.8 KiB
C++

#include "Postgres.h"
#include <Sql/sch_schema.h>
#include <Sql/sch_source.h>
using namespace Upp;
PostgreSQLTest::PostgreSQLTest()
{
CtrlLayout(*this, "PostgreSQL Test");
m_refresh << THISFN(ShowTestData);
m_array.SetTable(TESTPARTNER);
m_array.AddKey(TESTPARTNER_ID);
m_array.AddColumn(TESTPARTNER_NAME, "Name");
m_array.AddColumn(TESTPARTNER_ADDRESS, "Address");
}
bool PostgreSQLTest::OpenDB()
{
if(!m_session.Open("host=localhost dbname=test user=test password=test"))
{
Exclamation(Format("Error in open: %s", DeQtf(m_session.GetLastError())));
return false;
}
m_array.SetSession(m_session);
#ifdef _DEBUG
m_session.SetTrace();
#endif
SQL = m_session;
//schema
Progress p;
p.SetText(t_("Creating _DEBUG database"));
SqlSchema sch(PGSQL);
All_Tables(sch);
if(sch.ScriptChanged(SqlSchema::UPGRADE))
SqlPerformScript(sch.Upgrade(), p);
if(sch.ScriptChanged(SqlSchema::ATTRIBUTES)) {
SqlPerformScript(sch.Attributes(), p);
}
if(sch.ScriptChanged(SqlSchema::CONFIG)) {
SqlPerformScript(sch.ConfigDrop(), p);
SqlPerformScript(sch.Config(), p);
}
sch.SaveNormal();
return true;
}
bool PostgreSQLTest::InsertTestData()
{
Sql sql(m_session);
sql.ClearError();
sql.Begin();
sql * Delete(TESTPARTNER);
sql * Insert(TESTPARTNER)
(TESTPARTNER_NAME, "First Partner")
(TESTPARTNER_ADDRESS, "First Street")
;
sql * Insert(TESTPARTNER)
(TESTPARTNER_NAME, "Second Partner")
(TESTPARTNER_ADDRESS, "Second Street")
;
sql * Insert(TESTPARTNER)
(TESTPARTNER_NAME, "Third Partner")
(TESTPARTNER_ADDRESS, "Third Street")
;
if(!OkCommit(m_session, "Unable to insert test data."))
return false;
return true;
}
void PostgreSQLTest::ShowTestData()
{
m_array.SetOrderBy(TESTPARTNER_NAME);
m_array.Query();
}
GUI_APP_MAIN
{
PostgreSQLTest dlg;
if(dlg.OpenDB() && dlg.InsertTestData())
{
dlg.ShowTestData();
dlg.Run();
}
}