The model uses FLIBS Fortran module and C files to talk to SQLite. You should create the database, tables, and content ahead of time.

You should base your model on marsupial.f90 to make sure it includes the right features. Here's how you can design a subroutine "getOneMarsupial"

subroutine getOneMarsupial(query, name, latinName)
  ! expect the query
  character(len=*)		  :: query
  ! define the column return values
  character(len=50)			:: name, latinName

  ! connect to your database
  call sqlite3_open('marsupials.sqlite3', db)

  ! prepares query
  allocate( column(2) )
  call sqlite3_column_query( column(1), 'name', SQLITE_CHAR )
  call sqlite3_column_query( column(2), 'latinName', SQLITE_CHAR )

  ! actual query - where clause to the end
  call sqlite3_prepare_select( db, 'marsupials', column, stmt, "WHERE name = '" // trim(query) // "'")

  i = 1
  do
    ! iterate to end of returned rows
    call sqlite3_next_row(stmt, column, finished)
    if (finished) exit

    ! use column array to fill in name and latinName
    call sqlite3_get_column(column(1), name)
    call sqlite3_get_column(column(2), latinName)
    i = i + 1
  end do
endsubroutine