0

Ninox names vs user names

Is it possible to access a list of the Ninox element names used for the User defined names?

I inadvertently deleted a link to a table 'Projects' which Ninox has 'CA'.  I recovered the User name for CA via a back up but it would be super handy if one could download or view a chart of Ninox <> User element/field names.

25 replies

null
    • Alan_Cooke
    • 1 yr ago
    • Reported - view

     Is this something that could be achieved in Ninext?

      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

       I'm not sure I understand what you're trying to achieve. Could you provide more details?

      • Alan_Cooke
      • 1 yr ago
      • Reported - view

      Jacques TUR When a field is deleted any field that refers to that flags as an error and displays the Ninox applied fieldname.   For example I had a field named 'Projects' which is "known" by Ninox as CA.  If I delete 'Projects' either intentionally or unintentionally Ninox replaces 'PROJECTS' with 'CA'.

      If it were possible to somehow export a list of User Field Names  <> Ninox Field Names it would be a simple matter to rectify the issue.  That is to say I would know what 'CA' was before the mishap.
       

      Lorsqu'un champ est supprimé, tout champ qui y fait référence
      signale une erreur et affiche le nom de champ appliqué par Ninox.
      Par exemple, j'avais un champ nommé "Projets"
      qui est "connu" par Ninox sous
      le nom de CA. Si je supprime 'Projets' intentionnellement ou non, Ninox remplace 'PROJETS' par 'CA'.
      
      S'il était possible d'exporter d'une manière ou d'une autre une liste
      de noms de champs utilisateur <> noms de champs Ninox, il serait simple de corriger
      le problème. C'est-à-dire que je saurais ce qu'était 'CA' avant l'accident.
      • Alan_Cooke
      • 1 yr ago
      • Reported - view
      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

       ok, is clear now. 
      Try it on the console to find name of field from Ninox field Id (letter) :

      function getFieldName( tableName : text, fieldId : text ) do
      #{:text
      var t = database.schema.findType(tableName);
      var f = t?Object.values(t.fields).find(e => e.id==fieldId):null
      return (f ? f.caption : null)
      }#;
      end;
      
      getFieldName("Customer", "A");
      
    • Sean
    • 1 yr ago
    • Reported - view

    Alan,

    If you download your database file to your computer you can open it with a text editor. The schema should be at top of the file since any downloaded db will be compacted.

      • Alan_Cooke
      • 1 yr ago
      • Reported - view

      Good to know thanks

      • Sean
      • 1 yr ago
      • Reported - view

       Sorry, you need to get the noncompacted version of your database. I think you’ll have to contact Ninox for that.

      • Sean
      • 1 yr ago
      • Reported - view

      Geez, I really need to read everything carefully before I post! Alan I reread your original post so disregard my post about the non compacted version. I mistakenly thought you were trying to recover that part of your database.

      My original post stands as a method to get that information. "caption" is your field name and the letter before it is the Ninox name.

      • Ninox partner
      • RoSoft_Steven.1
      • 1 yr ago
      • Reported - view

        What I do is to download the Ninox database. As result you get the database name with the extention .ninox

      When you change that to the extention .zip, you can extract the database with a decompression program.

      And I think you could extract the wanted information out the file data.db then....

      (not sure though, Sean any idea?)

      • Sean
      • 1 yr ago
      • Reported - view

       That's what I would do if I still used the cloud version. Since I work with the Mac app and all my files are local, I can get the data.db file directly without extracting it. If I use "Save archive as" in the Mac app I would need to use the method you described to get to the data.db file.

      It looks like Jacques has provided a handy function to use though. 👍

      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

       you can obtain the schema directly with this function:

      function getDBConfig( ) do
         #{:text return JSON.stringify(database.schema.toJSON());
      }#;
      end;
      
      getDBConfig();
      
      • Sean
      • 1 yr ago
      • Reported - view

      Jacques TUR Sorry for the late reply. Long day in the Pacific time zone.

      I like it! I removed the toJSON() method and it didn't affect the output any. When I compared the strings using and not using that method, the length was the same. I also modified it to use the space parameter and that makes the output more readable.

      function getDBConfig() do
         #{:text return JSON.stringify(database.schema, null, 3);
      }#;
      end;
      
      getDBConfig();

      You can also use tab instead, but that creates a lot of whitespace.

      function getDBConfig() do
         #{:text return JSON.stringify(database.schema, null, '\t');
      }#;
      end;
      
      getDBConfig();
      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

       You can also use it directly as a JSON object (any) in Ninox to retrieve information from the database schema.

      function getFieldNameById( table : text, fieldId : text ) do
      var fr := {};
      var s := #{:any return database.schema}#;
      for t, tv in s.types do
       if tv.caption = table then
         for f, fv in tv.fields do
           if f = fieldId then
             fr := fv;
            end;
         end;
        end;
      end;
      fr.caption;
      end;
      
      getFieldNameById( "Customer", "A")
      
      • Sean
      • 1 yr ago
      • Reported - view

       Would you be interested in making a function to copy the initial database file object as a string to the clipboard? Another way of saying it is the file object that has just been read from the server and before it has been processed... the raw file.

      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

       I am still on vacation. I will look into it when I return next week.
      Just to clarify the need a bit, what would be, in your opinion, the differences between the raw schema and the processed schema ?

      • Sean
      • 1 yr ago
      • Reported - view

       No rush. For me, statistical information about database bloat. I started a thread on this topic here

      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

       The schema read from the server is database.originalSchema. This NativeJS function copies it to the clipboard in the form of formatted text.

      Be careful when manipulating the schema and orginialSchema variables. A wrong modification can permanently alter the database.

      #{
      var t = JSON.stringify(database.originalSchema, null, '\t');
      navigator.clipboard.writeText(t);
      }#;
      • Sean
      • 1 yr ago
      • Reported - view

      Jacques TUR Thank you. Unfortunately, that is not quite what I am asking for

      Sean said:
      Another way of saying it is the file object that has just been read from the server and before it has been processed... the raw file.

      Which means more than the schema. It includes everything from schemas to modified records to deleted records to modified Table columns. All of that is stored in the raw file. I have attached an example file.

      I can create a directory on my Mac where all of the other Ninox directories/data.db files are stored and rename that file to data.db and then open it with Ninox.

      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

       It will require me more investigation than I thought and it's not even sure that it's possible. If we do, what will it make it possible to do?

      • Sean
      • 1 yr ago
      • Reported - view

       Don't worry about it.

       said:
      If we do, what will it make it possible to do?
       said:
      For me, statistical information about database bloat.

      With the unprocessed file you could count how many old schema there are in your database file. Any time you make a change to your database structure and save the change a complete copy of your schema is appended to your database file. Even if you just made a spelling correction to one of your field names, a complete copy of the schema is appended to your database file. If someone has a lot of tables and formulas that can add up.

      Same goes for deleted records, modified table columns, modified data and I think relationships are handled separately from the schema. This is just a personal interest, but for users of the cloud version it could be useful information for managing their allotted space.

      • Business Analyst
      • Terry_Hopper
      • 1 yr ago
      • Reported - view

      Hi  . Does this use your NativeJS add-in?

      How do I get that working in my databases?

      Regards, Terry.

      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

       

      It would indeed be interesting to be able to extract the history of schema modifications, and why not the deleted records as well.

      However, on the cloud, only the latest schema is loaded, and the records are called as needed for displaying data in response to queries. The only time the file could be loaded in its entirety is when downloading a backup. I will check if this function is achievable.

      • Ninox developper
      • Jacques_TUR
      • 1 yr ago
      • Reported - view

      Terry Hopper 

      Yes, the function that retrieves the field name from its Ninox ID uses NativeJS with Ninext.

      If you want to install it, send me an email at jacques.tur@neuf.fr, and I will send you the installation procedure.

      • Sean
      • 1 yr ago
      • Reported - view

       

       said:
      However, on the cloud, only the latest schema is loaded

      ...into the database object? I'm sure it's the same for the Mac app as well. But where is the schema being loaded from? The stored text file? So, how does the code know where to look for the latest schema since it could be anywhere in the file? Also, you could have an old record that is somewhere near the top of the file, but if you modify a field much later that modification would be further down in the file.

       said:
      The only time the file could be loaded in its entirety is when downloading a backup.

      I'm fairly certain that download will be compacted, but I don't have a cloud account anymore so I can't confirm that.

      prototype.openDatabase or prototype.loadBootstrap 🤷‍♂️