-
-
Notifications
You must be signed in to change notification settings - Fork 19
fix(mysql): add native type mapping attributes #652
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
|
Warning Rate limit exceeded
⌛ How to resolve this issue?After the wait time has elapsed, a review can be triggered using the We recommend that you space out your commits to avoid hitting the rate limit. 🚦 How do rate limits work?CodeRabbit enforces hourly rate limits for each developer per organization. Our paid plans have higher rate limits than the trial, open-source and free plans. In all cases, we re-allow further reviews after a brief timeout. Please see our FAQ for further information. 📝 WalkthroughWalkthroughThis PR adds numerous new database field attribute modifiers and parameterized forms to the standard library model, introducing additional string, integer (including unsigned and parameterized tiny/medium), floating, blob/binary, and DateTime variants in Changes
Estimated code review effort🎯 2 (Simple) | ⏱️ ~12 minutes Poem
🚥 Pre-merge checks | ✅ 3✅ Passed checks (3 passed)
✏️ Tip: You can configure your own custom pre-merge checks in the settings. ✨ Finishing touches🧪 Generate unit tests (beta)
Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. Comment |
|
Claude finished @ymc9's task —— View job Pull Request ReviewI've analyzed this PR that adds MySQL native type mapping attributes to the ZModel standard library. Here's my comprehensive review: Review Checklist:
✅ Code Quality & Best PracticesExcellent work overall! The changes follow established patterns in the codebase:
Strong points:
🔍 Specific Changes AnalysisThe PR adds 15 new MySQL-specific database type attributes: String types:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Pull request overview
This PR adds MySQL-specific native type mapping attributes to the ZModel stdlib to improve compatibility with MySQL database types. These attributes are used to specify the exact MySQL native types when mapping ZModel fields to database columns.
Changes:
- Added MySQL text type attributes: TinyText, MediumText, and LongText for String fields
- Added MySQL integer type attributes: UnsignedInt, UnsignedSmallInt, MediumInt, UnsignedMediumInt, TinyInt, UnsignedTinyInt, and Year
- Added MySQL BigInt variant: UnsignedBigInt
- Added MySQL floating-point type attributes: Float and Double
- Added MySQL DateTime attribute and modified Date to accept an optional precision parameter
- Added MySQL binary data type attributes: LongBlob, Binary, VarBinary, TinyBlob, Blob, and MediumBlob
💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🤖 Fix all issues with AI agents
In `@packages/language/res/stdlib.zmodel`:
- Around line 447-471: The `@db.Date` attribute is incorrectly defined with a
precision parameter; update the attribute declaration for `@db.Date` so it has no
parameters (change attribute `@db.Date`(_ x: Int?) to attribute `@db.Date`() ) while
keeping its @@@targetField([DateTimeField]) @@@prisma metadata unchanged; ensure
any references expecting fractional-second precision use `@db.DateTime`(x),
`@db.Timestamp`(x), or `@db.Time`(x) instead.
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
|
Claude finished @ymc9's task —— View job Pull Request ReviewI've analyzed this PR that adds MySQL native type mapping attributes to the ZModel standard library. Here's my comprehensive review: Review Checklist:
✅ Code Quality & Best PracticesExcellent work overall! The changes follow established patterns in the codebase:
Strong points:
🔍 Specific Changes AnalysisThe PR adds 15 new MySQL-specific database type attributes: String types:
|
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
|
Claude finished @ymc9's task —— View job Pull Request ReviewI've conducted a comprehensive code review of this MySQL native type mapping attributes PR. Here are my findings: Review Checklist:
✅ Code Quality & Best PracticesExcellent work overall! The changes follow established patterns in the codebase:
🔍 Changes AnalysisThe PR originally added 22 new MySQL-specific database type attributes, but has since been corrected: ✅ Added correctly:
✅ Fixed based on reviewer feedback:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🤖 Fix all issues with AI agents
In `@packages/language/res/stdlib.zmodel`:
- Around line 481-487: The `@db.VarBinary` attribute currently defines its length
parameter as optional (`@db.VarBinary(_ n: Int?)`) which can emit invalid Prisma
schemas for MySQL; update the `@db.VarBinary` declaration in
packages/language/res/stdlib.zmodel to make the length required (change `Int?`
to `Int`) so the signature is `@db.VarBinary(_ n: Int)` while leaving `@db.Binary`
unchanged (it may remain `Int?`) and ensure any related validation or docs
referencing the VarBinary symbol reflect the required length.
…khq/zenstack-v3 into fix/mysql-native-mapping
|
Claude finished @ymc9's task —— View job Pull Request ReviewI've conducted a comprehensive code review of this MySQL native type mapping attributes PR. Here are my findings: Review Checklist:
✅ Code Quality & Best PracticesExcellent work overall! The changes follow established patterns in the codebase:
🔍 Changes AnalysisThe PR originally added 22 new MySQL-specific database type attributes, but has since been corrected: ✅ Added correctly:
✅ Fixed based on reviewer feedback:
|
Summary by CodeRabbit