Jump to content
TrinityCore

"unknown column" "missing table" "duplicate column" error / sql problems / SQLDriverLogFile < answer on 1st post of 1st page


Apple
 Share

Recommended Posts

For command line, you could execute: mysql -uroot -pascent -e "SHOW GRANTS;"

 

The line with "IDENTIFIED BY PASSWORD" isn't important. Just need to see the specific database grant listing.

 

As I believe I said before, to benefit other users that may run into the same problem, it would be best to keep the conversation here. Plus, if we run into a brick wall, you won't have to explain everything all over again when someone else tries to help. Public records are are a good thing, even if they do seem to take forever.

Link to comment
Share on other sites

Close, but not quite. The command I gave is what you run in a CMD command line window. When at the "mysql>" prompt, you should not need "-uroot -pascent -e" or the quotes. You do, however, need to end the query with a semicolon (;).

 

You aren't retarded, but you are showing your lack of knowledge of SQL. You may wish to read up on that if you intend to run your own server. Trust me, that will help, despite what some others will insist. Luckily, the syntax (command structure) is quite simple.

Link to comment
Share on other sites

You should have something like the following:

| GRANT ALL PRIVILEGES ON `world`.* TO 'root'@'localhost' WITH GRANT OPTION                                                              |
| GRANT ALL PRIVILEGES ON `characters`.* TO 'root'@'localhost' WITH GRANT OPTION                                                         |
| GRANT ALL PRIVILEGES ON `auth`.* TO 'root'@'localhost' WITH GRANT OPTION                                                               |

Your grants listing suggests an incomplete or improper MySQL setup.

 

Additional thought: In theory, your grants should be ok. My setup uses a modified version of the sql/create/create_mysql.sql file (changing the user and password as I saw fit).

Link to comment
Share on other sites

Hi all,

 

I'm completely new to this project, and so far I very much like what I see. I am a developer myself and I thought it would be fun to join in. I'd like to work on the latest 4.3.4 core. So I have a question... I've read all the tutorials to get a build working that is sync with a specific version of the core, but what if I wanted to actually use the latest core version? Its not clear if I need to install the updates from TDB, or if I should only install the updates found in the core? In any case, I'm guessing I need to start from the latest Full-TDB-5?

 

Thank you.

Link to comment
Share on other sites

If you're familiar with both C++ and SQL (MySQL specifically), you should be capable of using the updates from both the TDB repository as well as the updates from the core repository (assuming that you stick with the 4.3.4 branch...using the updates from the master branch would certainly mess up the database contents). There will be certain conflicts, but they will be easily filtered out by someone familiar with SQL. From there, you will find plenty of erroneous and missing functionality which you are more than welcome to contribute towards core and/or database development. All that is asked is that you follow the coding methods and SQL structure that is detailed (I forget where, but I think that's all mentioned on the forums here).

Link to comment
Share on other sites

Forgive me, but many of the "I can't get worldserver to run" posts are a result of people doing EXACTLY what the wiki says. Meaning, they don't apply the updates from the TC 4.3.4 repository, so the server fails to work. They can't ignore that update tree AND still run the server. So, how about amending that "don't use" clause to list the required exceptions?

 

For the record, I recently created a test world database. I started with the 434.05 full, applied the TDB updates, then applied all of the TC 4.3.4 world updates. I just wanted to see what the errors were. I seem to recall that there was only 3 or 4 (if that many, actually) "errors" that I filtered out. The only errors I saw were dealing with a table that was removed (it was something about creature AI). I can't speak for any other conflicting changes, though (i.e. updates that actually reverted things to pre-Cata settings). Is it possible that the "*434.sql" (102 of those as of rev adc4b3b46b0d) files are safe to use? I seem to recall that none of those had to be excluded in my test.

Link to comment
Share on other sites

Wiki also states to clone TC revision of the hash of the last sync. The only "safe" files to apply of TC repo are the ones altering db structure or creating new structures.

 

Excuse me? Do you realize that you effectively contradicted yourself there? If TC and TDB are in sync, there shouldn't be any sql updates from TC at all. Otherwise, anything that changes the DB structure would, supposedly, break that revision of the core. Or, are you saying the TDB repository is not as perfect as you guys keep insinuating?

Link to comment
Share on other sites

I say that TDB repo is outdated an wiki states to stay on TC revision of last TDB sync.

And no, i don't contradicted myself, i simply answered the question and the incorrect affirmation on a single line.

 

Fair enough. On the same line, however, separate concepts tend to blend together. You may wish to keep that in mind for future posts.

 

Just so this is available for others to find without asking it again and again:

  • What exactly is the point of the sql updates in the TC repository for the 4.3.4 branch?
  • Why are there updates specifically flagged 434 in the filename if they are still not to be used?
  • Why are there ANY updates in the 4.3.4 branch flagged with 335 in the filename?

I believe that having those questions asked and properly answered will help eliminate many of the threads created as a result of DB creation errors. Surely, you can agree with that, especially with those 335/434 files being available even when staying in sync with the TDB repository.

Link to comment
Share on other sites

1 and 2, they are temporaly there.

3 it's result of merging branches.

4) http://www.trinitycore.org/f/topic/1518-trouble-with-your-trinity-install-readme-1st-faqs/#entry42704 and still we have people asking the same question every time.

 

In other words, 1-3 are all the direct result of lazy developers. Fair enough. Before you take offense to that, what else would you call a developer that pushed sloppy content not meant for public use to a public repository? Temporary? Why was that content even pushed out? It can be shared via some other method that isn't revealed to the general public. If you guys don't know that, you really aren't qualified to work on a project such as this. I have code of my own that isn't ready for public use. It's not on my repository or published in any way because I don't want someone getting upset by it not working as expected or reverting functionality that they didn't want.

 

As for 4, I did perform a search relevant to the updates and 4.3.4, but it either wasn't listing that thread in the results or it was very low on the list (on a secondary page, maybe). However, "4.3.4 sql updates" had this thread as #2 on my results (#1 is a closed thread that doesn't answer the issue). That was a search for the entire site, not just this specific forum. Still want to say that using the search will answer perfectly every time? Don't be a fool and say "yes". That search term is pretty specific on the issue and should easily catch any thread mentioning the question/problem.

Link to comment
Share on other sites

No, 1-3 is not direct result of lazy developers, those files must be there for people with knowledge of how to do properly things.

Well help and suport forum have this description linking to that thread " Most of your questions about instalation problems have the answer -- -- -- HERE -- -- --"

Link to comment
Share on other sites

+Kylroi I see by many of your comments that you don't know how things around here work, but, one thing I can tell you will never change (because I have tried for years to change it) the Trinitycore repos are NOT public releases, they are dev repos that the public has access to, and, as such, the devs have no particular responsibility to ensure that anyone will be able to compile or run anything from them.

Link to comment
Share on other sites

No, 1-3 is not direct result of lazy developers, those files must be there for people with knowledge of how to do properly things.

 

And... this is the question I've been asking al along: where do people who don't know how to do things properly learn how to do things properly (when the guides seem broken)?

 

The standard answers are:

  • If you can't figure it out, you shouldn't be running a server
  • That branch is in alpha so it's not supported

both of which contradict the whole methodology behind an open-source, public repo. It may not be ready for public use but there should be a modicum of support for potential developers who can't get it running. Otherwise just mark the repo private until its ready but then you lose potential developers and testers.

Link to comment
Share on other sites

No, the guides aren't broken, they state for 4.3.4 branch you must stay on the last sync revision. Also if you have low knowledge of sql (like myself) you can make yourself the core work on 4.3.4 head, it's not hard at all to start core and look the startup errors asking you for sql structure/new tables, if with that they can't figure what to do, i must say sorry, stop using computer because you are to stupid to read.

Link to comment
Share on other sites

First of all, developers who actually know how to code can easily figure out any code and SQL errors. I know this based on the experience I've had with systems that I had zero knowledge about, but had the ability to actually write code from scratch. It would be all better to stop bitching about useless things, if you personally aren't the coder (SQL "devs" are not coders... really...).

Link to comment
Share on other sites

 Share

  • Recently Browsing   0 members

    No registered users viewing this page.


  • Similar Content

    • By xgamerninjax
      Hello all, first time posting here and it's really got me scratching my head.
      I've compiled everything on my own computer, and then transferred everything to a host computer so the server can stay live. The server was running fine for a month or so and then suddenly it just crashes when it hits "Loading C++ scripts", exiting saying "caught signal 22"
      I tried setting up the host computer from scratch and transferred everything over fresh and it's still happening for some reason. (Note, I can run the server perfectly on my personal pc where I compiled it.)
      Any help would be greatly appreciated, thanks!
      3d7e3a40e2b3+_worldserver.exe_[1-4_15-19-45].dmp 3d7e3a40e2b3+_worldserver.exe_[1-4_15-19-45].txt
    • By Rochet2
      A lot of people have asked how to debug so I made this short guide on how to set up debugging.
      This guide only tells you how to actually set up debugging in TrinityCore on Windows and Linux.
      This will not explain the basics of debugging. You can google those or play around with the debugger to learn.
      Here are a few videos that explain how to actually debug after setting debugging up on visual studio: https://youtu.be/0ebzPwixrJA and linux: https://www.youtube.com/watch?v=sCtY--xRUyI

      This guide contains multiple guides. Each list of bullet points is it's own guide.
      Make sure you can run the server normally before trying to debug.

      Windows:
      On Windows before anything you should check these
      - Before debugging or making crashlogs etc. with Visual Studio you must compile the core in "Debug" instead of "Release". You can select this in "Build>Configuration Manager" or at the top of Visual Studio window http://i.imgur.com/5oHd59j.png
      - You also need to move the new pdb files generate by compiling in debug mode on Visual Studio from the compile output folder (bin) to your server folder - these files contain information needed for debugging.
      - It is assumed that Solution Explorer is open. Open it by selecting "View>Solution Explorer" in Visual Studio http://i.imgur.com/hkW6Gk0.png
      -- You may want to click on the Home icon to reset the view on Solution Explorer http://i.imgur.com/N8UPwDh.png
      - You can place breakpoints in Visual Studio editor by right clicking a line of code and selecting "Breakpoint>Insert Breakpoint" http://i.imgur.com/L2TxBVG.png
      - At the top of the window you should see controls for stepping and continuing when you have started to debug.
      - Here is a video showing the basic Visual Studio functionality https://www.youtube.com/watch?v=Ijdk4z8-2OI
      Fastest way to debug on windows. This is the easiest way to start up debugging a script.
      - Start the authserver and worldserver normally
      - Open TrinityCore.sln in Visual Studio. This is what you usually open when you want to compile the core
      - In Visual Studio at the top select "Debug>Attach to process...>worldserver.exe" and click "Attach" http://i.imgur.com/jDEI2Hq.png
      - You are now debugging
       
      The second slower way of debugging on windows. This is useful for debugging something that occurs in the startup of the server.
      - Open TrinityCore.sln in Visual Studio. This is what you usually open when you want to compile the core
      - In solution explorer right click on worldserver and select "Set as StartUp Project" http://i.imgur.com/wvMzeRA.png
      - In solution explorer right click on worldserver and select "Properties" http://i.imgur.com/rTNEF9O.png
      -- In Properties you should go to "Configuration Properties>Debugging" and edit "Working Directory" to point to the server folder. For me this is the default compile folder so I use "$(OutDir)" http://i.imgur.com/aRI29fB.png
      - Start the authserver normally
      - Start the worldserver by selecting "Debug>Start Debugging". The server will start with debugging attached from the beginning http://i.imgur.com/cg1KJNw.png
      - You are now debugging
      Crashlogs on windows. Once you have a way to reproduce a crash you can get a crashlog that can help you resolve it.
      - After compiling the core in "Debug" instead of "Release" start up the worldserver and authserver
      - Reproduce the crash you have
      - In the server folder there is now a folder called Crashes that contains txt and dmp files. http://i.imgur.com/9eQIdql.png
      - You can open the txt files in text editors http://i.imgur.com/EH6R17E.png
      -- At the top of a txt file there is some information about your system and below it there is the Call Stack and below that there are Variables of each part of the call stack
      -- The Call Stack will tell you at the top what was the last function call before crashing and what function calls led to that function call.
      -- Next to the function names there is the file that the function is defined in and the line number the code was executing in that function.
      -- In the Variables section you can inspect variables that were present at each function call.
      -- Based on this information you are often able to see what crashed or get a better view of what you need to inspect more in your code.
      - The dmp file can be opened in Visual Studio
      -- Open TrinityCore.sln in Visual Studio. This is what you usually open when you want to compile the core
      -- Drag and drop the dmp file to Visual Studio
      -- In the window that opens click to "Debug with Native Only" http://i.imgur.com/OgyU2kM.png
      -- In the window popup click "Break" http://i.imgur.com/4jDzqRn.png
      -- You are now in a state like you would have hit a break point in the code or a crash while debugging. You can inspect the call stack and the variables.
      Edit and continue on windows. When debugging this allows you to change the code and without restarting the server apply those changes so they actually work ingame.
      - Open TrinityCore.sln in Visual Studio. This is what you usually open when you want to compile the core
      - In solution explorer right click on worldserver and select "Properties" http://i.imgur.com/rTNEF9O.png
      -- In Properties select "Configuration Properties>Linker>General" and set "Enable Incremental Linking" to "Yes". http://i.imgur.com/caQqwN5.png
      -- In Properties select "Configuration Properties>Linker>Advanced" and set "Image Has Safe Exception Handlers" to "No". http://i.imgur.com/FYzN8Ks.png
      -- In Properties select "Configuration Properties>C/C++>General" and set "Debug Information Format" to "Program Database for Edit And Continue". http://i.imgur.com/pxQ6I8N.png
      - At the top of the window select "Tools>Options". In the Options select "Debugging>General" and in there select "Enable Edit and Continue", "Enable Native Edit and Continue" and "Require source files to exactly match the original version".
      - Compile the server for the changes to take effect.
      - Set up "The second slower way of debugging" (I did not test edit and continue on other configurations)
      - Start the authserver normally
      - Start the worldserver by selecting "Debug>Start Debugging".
      - Try edit a cpp file a little and save it.
      - At top of Visual Studio window select "Debug>Apply Code Changes" and wait until the changes are applied. Warning: it can take considerable amount of time for the changes to be applied. http://i.imgur.com/77pb58E.png
      - If you have issues, be sure to check the error messages in Output. You can view it by selecting "View>Output" http://i.imgur.com/4cIznW9.png
      - This guide was written based on https://msdn.microsoft.com/en-us/library/esaeyddf.aspx and https://blogs.msdn.microsoft.com/vcblog/2015/07/22/c-edit-and-continue-in-visual-studio-2015/
      Linux:
      First we need to compile the server in debug mode.
      - Compile the server with the cmake flag -DCMAKE_BUILD_TYPE=Debug

      Debugging on linux. You can debug on linux by using GDB.
      - Here is a good video about it: https://www.youtube.com/watch?v=sCtY--xRUyI
      - Basically you
      -- Start the authserver
      -- Start the worldserver by using "gdb ./worldserver"
      -- Enter breakpoints by using break command on gdb
      -- Use the run command on gdb to start the server
      -- You are now debugging
      - You may also be interested in using VScode or some other more visual debuggers. https://www.youtube.com/watch?v=B0xTgyCwsAo
      Crashlogs on linux. Once you have a way to reproduce a crash you can get a crashlog that can help you resolve it.
      - Take crashreport.gdb from /contrib/debugger from source folder and place it to your server folder
      - Start the authserver
      - Start the worldserver by using "gdb -x crashreport.gdb ./worldserver"
      - Reproduce your crash
      - There should be a backtrace.log in your server folder that contains information about the crash like the callstack and variables in each function call in the call stack
      - This guide was written based on https://github.com/TrinityCore/TrinityCore/blob/master/contrib/debugger/README
      Running valgrind on linux. This helps you find memory errors like invalid reads and writes and memory leaks.
      - Here is a good video about it: https://www.youtube.com/watch?v=fvTsFjDuag8
      - Basically you
      -- Start the authserver
      -- Start the worldserver by using "valgrind ./worldserver"
      -- Run your code that you want to analyze and close the server
      -- The console or an output log should contain the valgrind log
    • By reyne
      Hey there!

      I've followed a few threads here about map extraction, and am still having issues. Originally, I was having the issue described here.
      After following the advice given in that thread (creating characters of both BC races and running around for a bit), I am no longer getting that error, however now I get the following error while trying to extract maps:

      `Error loading World\Maps\Expansion01\Expansion01_42_6.adt`

      This repeats for every line in Expansion01, and then the extractor crashes.

      I'm not sure where else to go from here.

      Thanks for your help

      Edit: I've created an 85 on an i85 server and flown all around Outland now, same issue.
    • By Uee
      I recently found the Trinity Cataclsym Preservation Project and thought I will try it out.
      I am already running 3.3.5a and Master - both server run great
      Pulled 4.3.4 down using Git and built it same way as others:
      boost_1_73_0 cmake 3.17.2 Mysql 5.7.30 VS Community 2019 Built fine - no issue. Used 'Extractor.bat' to run all the map extractors - worked great!
      Noticed there was extra file 'connection_patcher.exe`, ran that - worked great! Now have "wow_patched" and use this to launch client
      MySQL runs in standalone mode, -initialize, added base sql files, imported, auth and character sql files
      Configured both the .conf files and passwords, IPs etc are all in place.
      Note: When loading the exe and built conf file, bnetserver complain about these items missing, so I add them:
      Updates.AutoSetup = 1 Updates.EnableDatabases = 0 LoginDatabase.SynchThreads = 1 Load up Mysql - loads fine
      Load up bnetserver and appears to load ok - last few lines look like this:
      Connected to MySQL database at 127.0.0.1
      DatabasePool 'auth' opened successfully. 2 total connections running.
      Started auth database connection pool.
      Listening on connections from worldservers on port 1118...
      Load up worldserver and it adds the FULL world and hotfixes, then applied all updates (confirmed archived in SQL) - last few lines look like this:
      Calculate next monthly quest reset time...
      Calculate random battleground reset time...
      Calculate guild limitation(s) reset time...
      Calculate next currency reset time...
      World initialized in 0 minutes 13 seconds
      TrinityCore rev. d0c7bbab40bc 2020-05-06 00:01:21 +0200 (master branch) (Win64, RelWithDebInfo, Static) (worldserver-daemon) ready...
       
      There are no db errors in logs.
      Config.wtf contain portal, realmlist as remote server and patchlist as localhost.
      When I try to connecting using "user@local" and password I get immediately disconnected.
      What I did noticed different is that the bnetserver doesnt add "Added realm "Battle for Azeroth" at 192.168.10.213:8085." (From my Master log) 
      3.3.5a also have this line as last line in authserver - but 4.3.4 is not giving me this one.
      Realmlist table is accurate with right information.
      Anyone know why bnetserver is not starting me realm?
       
    • By Deer_Hunter
      Hello all,
      I just updated from the latest Git 
      Trinity Core REV. ac6baa547376 + 2020-02-21  3.3.5 Branch.
      I'm getting this error after crash.
      Problem signature:
        Problem Event Name:    APPCRASH
        Application Name:    worldserver.exe
        Application Version:    0.0.0.0
        Application Timestamp:    5e50a462
        Fault Module Name:    StackHash_f12f
        Fault Module Version:    6.3.9600.19629
        Fault Module Timestamp:    5e2fdc0d
        Exception Code:    c0000374
        Exception Offset:    PCH_9E_FROM_ntdll+0x0000000000090D0A
        OS Version:    6.3.9600.2.0.0.272.7
        Locale ID:    1033
        Additional Information 1:    f12f
        Additional Information 2:    f12f0934d3e965f73c68e60f20f2cd40
        Additional Information 3:    7595
        Additional Information 4:    7595e4d8d703db9dcd3d2f6ea540e357
      the exception code says its a Heap error,  I'm not sure how to troubleshoot this.
      Thanks
×
×
  • Create New...