Comments (9)
Very strange. I'll have to look into both of these when I get a chance.
from ash_postgres.
I believe I've just found and fixed the other issue as well :)
from ash_postgres.
Interestingly, I actually needed a migration to fix two references and they were generated differently -
def down do
# This one will work
drop constraint(:instance_logs, "instance_logs_instance_id_fkey")
alter table(:instance_logs) do
modify :instance_id,
references(:instances,
column: :id,
prefix: "public",
name: "instance_logs_instance_id_fkey",
type: :uuid
)
# I don't even know where this came from, the column has not changed
modify :associated_email, :text
end
# This one won't work
alter table(:experiments) do
modify :organisation_id,
references(:organisations,
column: :id,
prefix: "public",
name: "experiments_organisation_id_fkey",
type: :uuid
)
end
drop constraint(:experiments, "experiments_organisation_id_fkey")
end
from ash_postgres.
Interesting...so I think what might be happening is a non deterministic sorting. I was having trouble with the original sorting algorithm so I switched it to use digraph, and without the proper dependency, it could sometimes come out in the right order and sometimes in the wrong. Thanks for the report :) will take a look
from ash_postgres.
# I don't even know where this came from, the column has not changed
modify :associated_email, :text
This is concerning.
from ash_postgres.
That one might be a separate issue - I have a field associated_email
which is text, and I added an association that also uses it as a possible lookup field. (The email might match a valid user, but might not.)
belongs_to :user, MyApp.Accounts.User do
api MyApp.Accounts
source_attribute :associated_email
destination_attribute :email
end
Adding the association is what caused the migration to add modify :associated_email, :text
to both up
and down
.
from ash_postgres.
Could it be because the default field type for belongs_to
is :uuid
? Is the up
migration changing the field type to :uuid
? You might want attribute_type :string
.
from ash_postgres.
Maybe. No, both, are setting it to text -
def up do
alter table(:instance_logs) do
modify :associated_email, :text
end
end
def down do
alter table(:instance_logs) do
modify :associated_email, :text
end
end
from ash_postgres.
Pushing a fix for the unrollback-able migration. Still not sure on the unnecessary attribute migration, but we'll just have to leave that for another issue :)
from ash_postgres.
Related Issues (20)
- Regression installing ash_uuid extension HOT 1
- Polymorphic resource belongs_to relationship error HOT 1
- Using ref in a filter gives an error in ash 3 HOT 3
- Custom index unexpectedly dropped when upgrading to 2.0 HOT 8
- parent does not work from within an aggregate filter HOT 1
- protocol Jason.Encoder not implemented for dynamic ([], []) of type Ecto.Query.DynamicExpr HOT 1
- After upgrading to Ash 3 and latest postgres, complex nested aggregate fails HOT 1
- PSQL QUERY ERROR on updating json fields with nested objects containing arrays HOT 1
- Canβt rollback only 1 migration ago with `mix ash.rollback` HOT 2
- Proposal for `ash_postgres.squash_snapshots` mix task HOT 1
- Changing identities leads to generation of erroneous migrations HOT 1
- The maximum length of the index name is not considered HOT 2
- `Identity.where` is not working HOT 3
- Removing an attribute generates a migration with commented out changes, but snapshot with the changes HOT 5
- Handle the new Ecto parameterized type format
- Error thrown if relationship aggregate is used in update with atomic_update HOT 4
- Don't sort identity keys when creating unique indexes
- Updates from GraphQL broken
- Exceeding index limit gives confusing error message
- NaiveDateTime value breaks queries with Map type HOT 6
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
π Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. πππ
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google β€οΈ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from ash_postgres.