QSqlTableModel() empty on Ubuntu but works on Windows ?
-
Inside that class I have a function that generates the
QSqlTableModel
You don't want to directly create a
QSqlTableModel
anywhere, you want it now to create aMyTableModel
. E.g if you currently have anew QSqlTableModel
somewhere it now goesnew MyTableModel
. This is basic C++ sub-classing, I don't know whether you're confused over that.include it and create model using
MyTableModel *model = new MyTableModel(nullptr, db);
instead I still get a protected function error when calling itsselectStatement()
member.Assuming you've got the first bit right, you still cannot call a
protected
method on an instance from outside of theMyTableModel
class code, that's whatprotected
is all about. You will need something like the definition I showed you ofQString MyTableModel::selectStatement() const
. You can either then write anotherpublic
method inMyTableModel
which calls it and the outside world can go via that public method, or (as I do) override all the methods inMyTableModel
which do queries, updates etc. and have them print it out. It takes a few minutes to write these override functions, but once you have them from then on it's a lot easier to see what's going on, do logging, handle any errors etc. from theQSql...
classes you use. -
Would you be able to provide a small step by step guide to reproduce your test database ? Meaning the command you are currently using on your Linux machine to create the role and the database.
-
@SGaist Hi, I just use psql to create the database/table/user.
CREATE DATABASE my_db WITH OWNER = postgres ENCODING = 'UTF8' TABLESPACE = pg_default CONNECTION LIMIT = -1;
CREATE ROLE my_user WITH LOGIN NOSUPERUSER INHERIT NOCREATEDB NOCREATEROLE NOREPLICATION ENCRYPTED PASSWORD 'md5hidden';
CREATE TABLE public.my_table ( example_column character varying COLLATE pg_catalog."default", ) TABLESPACE pg_default; ALTER TABLE public.my_table OWNER to postgres; GRANT INSERT, SELECT, DELETE ON TABLE public.my_table TO my_user;
So for example:
sudo -u postgres psql -c 'one of the above blocks of code'
So here
my_db
is the database name,my_user
is the role I'm using to access the table andmy_table
is the table name. -
Sorry I did not had time to test the database.
One thing that you could try (I don't think it would change anything but worth a try), reorder the database setup and add your custom role and it setup both at the end.
-
@SGaist said in QSqlTableModel() empty on Ubuntu but works on Windows ?:
Sorry I did not had time to test the database.
One thing that you could try (I don't think it would change anything but worth a try), reorder the database setup and add your custom role and it setup both at the end.
I guess I could try that but why would the error be
QSqlError("", "Unable to find table logs", "")
then ?
-
Gut feeling: PostgreSQL namespace.
-
@SGaist said in QSqlTableModel() empty on Ubuntu but works on Windows ?:
Gut feeling: PostgreSQL namespace.
I had a look, but I don't quite understand how it applies to this...
-
The database role must have access to the namespace in order to access the relation it contains.
There might be a glitch there.
-
@SGaist said in QSqlTableModel() empty on Ubuntu but works on Windows ?:
The database role must have access to the namespace in order to access the relation it contains.
There might be a glitch there.
Yet the same role (same exact application/code) works fine on Windows ?